使Textview显示SQLite信息



好了接下来的代码在我的DataBaseHandler

    // Getting single contact
    Database getContact(int id) {
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.query(TABLE_MOVIES, new String[] { KEY_ID,
    ,KEY_SUM,KEY_ACT,KEY_TRAILER,KEY_PREVIEW,KEY_DIR,KEY_WRI }, KEY_ID + "=?",
    new String[] { String.valueOf(id) }, null, null, null);
    if (cursor != null)
    cursor.moveToFirst();
    Database contact = new Database(Integer.parseInt(cursor.getString(0)),
    cursor.getString(1),cursor.getString(2),cursor.getString(3),cursor.getString(4),cursor.getString(5),
cursor.getString(6),cursor.getString(7));
return contact;
    }

info.java类

protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.info);
        DatabaseHandler db = new DatabaseHandler(this);
                // for this example i want to read out ID 15 in my database
        db.getContact(15);
    }

database.java类

// getting movie_director
            public String getMD(){
                return this._movie_director;
            }
            // setting movie_director
            public void setMD(String movie_director){   
                this._movie_director = movie_director;
            }

包含textView的info.xml文件

   <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge" />

在这种情况下,我想显示电影导演在textview从SQLite数据库,但我被困后的db.getContact(15);(见info.java类)。我可以调用数据库,但我不知道如何从我的DatabaseHandler检索信息,并把它放在一个Textview。我试着做db.getMD();,但它不工作,以这种方式检索它。什么好主意吗?

你的getContact()函数返回一个Database对象,但是你正在调用getMD()方法到你的DatabaseHandler

我认为首先你应该把类Database重命名为类似Contact的东西,并在你的getContact()函数中返回它。然后将返回值存储在一个变量中,并调用函数getMD()。代码可以是这样的:

  DatabaseHandler db = new DatabaseHandler(this);
  Contact contact = db.getContact(15); //This is your what you call Database object
  //get View element
  TextView contactTextView = (TextView) findViewById(R.id.textView2);
  //Set contact information in the TextView
  contactTextView.setText(contact.getMD());

最新更新