[英]Trouble With SimpleCursorAdapter and Importing to Listview
我在这里有点茫然,为什么我的listview不会用简单的数据库信息填充。 任何帮助将不胜感激。 我的SQL语句有问题吗? 我以为它是正确的印象,但是我想我的光标可能是错误的。 或者也许我的simplecursoradapter没有任何意义(我意识到它已被弃用,但认为它仍然可以工作)
package com.example.firstdatabase;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.database.sqlite.SQLiteDatabase;
import android.widget.SimpleCursorAdapter;
import android.database.Cursor;
import android.content.Context;
import android.widget.ListView;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.list_view_test);
SQLiteDatabase db = openOrCreateDatabase("MyDB", MODE_PRIVATE, null);
db.execSQL("CREATE TABLE IF NOT EXISTS FunnyNames (Email VARCHAR, FirstName VarChar, LastName VARCHAR);");
db.execSQL("INSERT INTO FunnyNames VALUES('hello@aol.com', 'Jeff', 'Bath');");
Cursor cur = db.rawQuery("SELECT Email FROM FunnyNames", null);
cur.close();
db.close();
ListView listview = (ListView) findViewById(R.id.listView1);
SimpleCursorAdapter sca = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1,
cur,
new String[] {"1"},
new int[] {R.id.textView1}
);
listview.setAdapter(sca);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
这是我的列表视图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" >
<ListView
android:id="@+id/listView1"
android:layout_width="188dp"
android:layout_height="307dp" >
</ListView>
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="1" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="2" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="3" />
</LinearLayout>
谢谢!
游标适配器需要活动的游标和数据库。 在此代码中,您将在将游标传递给适配器之前关闭游标和数据库。
传递给CursorAdapter
的游标必须包含名为_id
的列。
使用SQLiteOpenHelper
来管理数据库,尤其是重写其onCreate()
来创建和填充数据库。 例如,现在每次调用onCreate()
活动时(例如,启动应用程序或更改设备方向),您都会在数据库中获得新的一行数据。
如果您使用SimpleCursorAdapter填充列表视图,则您的光标应具有“ _id”作为列。
请修改您的db.execSQL(“如果不存在,则创建表FunnyNames(_id整数主键自动递增,电子邮件VARCHAR,FirstName VarChar,LastName VARCHAR);”);
请参考链接以进一步说明
http://developer.android.com/guide/topics/providers/content-provider-basics.html#DisplayResults
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.