我有一个名为“master”的表,其中包含列id,姓名,姓氏,性别和名称
当我发出一个查询来获得一个Cursor对象为CursorAdapter我得到:
IllegalArgumentException: column '_id' does not exist when call to CursorAdaptor
但是我没有名为“_id”的列表.
有人可以告诉我为什么我得到这个错误?
这是堆栈跟踪:
07-13 15:45:40.582: WARN/System.err(295): java.lang.IllegalArgumentException: column '_id' does not exist 07-13 15:45:40.592: WARN/System.err(295): at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:314) 07-13 15:45:40.592: WARN/System.err(295): at android.widget.CursorAdapter.changeCursor(CursorAdapter.java:257) 07-13 15:45:40.602: WARN/System.err(295): at com.praumtech.names4baby.ui.NamesListAdapter.setCursor(NamesListAdapter.java:63) 07-13 15:45:40.602: WARN/System.err(295): at com.praumtech.names4baby.ui.BoysNamesListActivity.initNameList(BoysNamesListActivity.java:79) 07-13 15:45:40.602: WARN/System.err(295): at com.praumtech.names4baby.ui.BoysNamesListActivity.onCreate(BoysNamesListActivity.java:49) 07-13 15:45:40.602: WARN/System.err(295): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1123) 07-13 15:45:40.602: WARN/System.err(295): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2364) 07-13 15:45:40.612: WARN/System.err(295): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2417) 07-13 15:45:40.612: WARN/System.err(295): at android.app.ActivityThread.access$2100(ActivityThread.java:116) 07-13 15:45:40.612: WARN/System.err(295): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1794) 07-13 15:45:40.612: WARN/System.err(295): at android.os.Handler.dispatchMessage(Handler.java:99) 07-13 15:45:40.621: WARN/System.err(295): at android.os.Looper.loop(Looper.java:123) 07-13 15:45:40.621: WARN/System.err(295): at android.app.ActivityThread.main(ActivityThread.java:4203) 07-13 15:45:40.621: WARN/System.err(295): at java.lang.reflect.Method.invokeNative(Native Method) 07-13 15:45:40.621: WARN/System.err(295): at java.lang.reflect.Method.invoke(Method.java:521) 07-13 15:45:40.621: WARN/System.err(295): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791) 07-13 15:45:40.621: WARN/System.err(295): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549) 07-13 15:45:40.631: WARN/System.err(295): at dalvik.system.NativeStart.main(Native Method)
解决方法
这是因为CursorAdapter在它正在使用的表中必须有一个_id列.
使用Android应用程序中的数据库(sqlite),最好在所有表中添加一个名为_id的列,以便能够使用CursorAdapter.
或者,您可以编写一个sql语句
select member_id as _id from member _table where ....."
以获得可以与CursorAdapter一起使用的Cursor.
这在CursorAdaptor的documentation中指定:
Adapter that exposes data from a Cursor to a ListView widget. The Cursor must include a column named “_id” or this class will not work.”