问题描述
我想从一个SQLite数据库获取数据并通过SimpleCursorTreeAdapter填充我ExpandableListView,但它somewehere失败。我真的找不到什么是错的,甚至不知道在异常发生...
I want to get data from a SQLite db and populate my ExpandableListView via a SimpleCursorTreeAdapter, but it fails somewehere. I really can't find what's wrong, don't even know where the exception is happening...
MyExpandableListAdapter:
MyExpandableListAdapter:
private class MyExpandableListAdapter extends SimpleCursorTreeAdapter
{
public MyExpandableListAdapter(Context context, Cursor cursor,
int groupLayout, String[] groupFrom, int[] groupTo,
int childLayout, String[] childFrom, int[] childTo) {
super(context, cursor, groupLayout, groupFrom, groupTo, childLayout, childFrom,
childTo);
// TODO Auto-generated constructor stub
}
@Override
protected Cursor getChildrenCursor(Cursor groupCursor) {
Log.d("Calling getChildrenCursor()","OK");
Cursor childrenCursor = dbAdapter.getTrackedValuesByDate(groupCursor.getString(groupCursor.getColumnIndex(DbAdapter.KEY_VALUE_DATE)));
Log.d("getChildrenCursor()", DatabaseUtils.dumpCursorToString(childrenCursor));
startManagingCursor(childrenCursor);
return childrenCursor;
}
}
下面是在我的活动设置ListAdapter相关部分:
Here's the relevant part in my activity to set the ListAdapter:
private void fillData()
{
Cursor dateCursor = dbAdapter.getAllDates();
startManagingCursor(dateCursor);
Log.d("fillData()", DatabaseUtils.dumpCursorToString(dateCursor));
MyExpandableListAdapter myAdapter = new MyExpandableListAdapter(this,
dateCursor,
R.layout.expandablelist_header_date,
new String[] {DbAdapter.KEY_VALUE_DATE},
new int[]{R.id.expandablelist_header_date},
R.layout.listview_tracked_values,
new String[] {DbAdapter.KEY_INDICATOR_NAME, DbAdapter.KEY_INDICATOR_UNIT, DbAdapter.KEY_VALUE_VALUE},
new int[]{R.id.list_trackedvalue_indicatorname, R.id.list_trackedvalue_unit, R.id.list_trackedvalue_value });
Log.d("fillData()", "Creation successful");
this.expandableList.setAdapter(myAdapter);
Log.d("fillData()", "Adapter set");
}
下面是我dbAdapter两个常用的功能:
Here are the two used functions of my dbAdapter:
public Cursor getTrackedValuesByDate(String dateString)
{
Cursor cursor = this.db.rawQuery("select * from "+DB_INDICATORS_TABLE+" i,"+ DB_VALUES_TABLE+" v where i."
+ KEY_INDICATOR_ROWID+"=v."+KEY_VALUE_INDICATOR_ID+" and v."+KEY_VALUE_DATE+"='"+dateString+"'", null);
if(cursor!=null)
cursor.moveToFirst();
Log.d("getTrackedValuesByDate()", DatabaseUtils.dumpCursorToString(cursor));
return cursor;
}
public Cursor getAllDates()
{
Cursor c = this.db.rawQuery("Select distinct "+KEY_VALUE_DATE+" from "+DB_VALUES_TABLE, null);
if(c!=null)
c.moveToFirst();
Log.d("getAllDates()", DatabaseUtils.dumpCursorToString(c));
return c;
}
和LogCat中的最后的输出:
And finally the output of LogCat:
09-07 12:05:06.912: D/fillData()(1317): >>>>> Dumping cursor android.database.sqlite.SQLiteCursor@41219990
09-07 12:05:06.912: D/fillData()(1317): 0 {
09-07 12:05:06.912: D/fillData()(1317): trackDate=07.09.2012
09-07 12:05:06.912: D/fillData()(1317): }
09-07 12:05:06.912: D/fillData()(1317): 1 {
09-07 12:05:06.912: D/fillData()(1317): trackDate=08.08.2012
09-07 12:05:06.912: D/fillData()(1317): }
09-07 12:05:06.912: D/fillData()(1317): <<<<<
09-07 12:05:06.952: D/fillData()(1317): Creation successful
09-07 12:05:06.952: D/fillData()(1317): Adapter set
09-07 12:05:07.012: E/CursorWindow(1317): Failed to read row 0, column -1 from a CursorWindow which has 2 rows, 1 columns.
09-07 12:05:07.012: D/AndroidRuntime(1317): Shutting down VM
09-07 12:05:07.048: W/dalvikvm(1317): threadid=1: thread exiting with uncaught exception (group=0x40a13300)
09-07 12:05:07.145: E/AndroidRuntime(1317): FATAL EXCEPTION: main
09-07 12:05:07.145: E/AndroidRuntime(1317): java.lang.IllegalStateException: Couldn't read row 0, col -1 from CursorWindow. Make sure the Cursor is initialized correctly before accessing data from it.
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.database.CursorWindow.nativeGetLong(Native Method)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.database.CursorWindow.getLong(CursorWindow.java:507)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.database.AbstractWindowedCursor.getLong(AbstractWindowedCursor.java:75)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.CursorTreeAdapter$MyCursorHelper.getId(CursorTreeAdapter.java:436)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.CursorTreeAdapter.getGroupId(CursorTreeAdapter.java:191)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.ExpandableListConnector.getItemId(ExpandableListConnector.java:422)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.AbsListView.obtainView(AbsListView.java:2288)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.ListView.measureHeightOfChildren(ListView.java:1244)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.ListView.onMeasure(ListView.java:1156)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.view.View.measure(View.java:15172)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.RelativeLayout.measureChild(RelativeLayout.java:602)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:415)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.view.View.measure(View.java:15172)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
09-07 12:05:07.145: E/AndroidRuntime(1317): at android.view.View.measure(View.java:15172)
正如你所看到的,我上次是的debug.log该适配器设置为ListView的,但随后
这是finnito ...
我甚至不得到的被覆盖的功能getChildrenCursor(光标groupCursor)曾经被称为日志消息,所以错误发生了,我不知道在哪里...
As you can see, my last debug.log is that the Adapter is set to the ListView, but thenit's finnito...I don't even get a log message that the overriden function getChildrenCursor(Cursor groupCursor) is ever called, so the error happens I don't know where...
帮助,我会在这个疯狂...
Help, I'm going mad on this...
推荐答案
从的,这是SimpleCursorTreeAdapter的间接母公司可以看到:
From the documentation of CursorTreeAdapter, which is an indirect parent of SimpleCursorTreeAdapter you can see that:
光标必须包含一个名为_id列或本级将无法工作。
你是从你的查询丢失。
这篇关于使用SimpleCursorTreeAdapter为ExpandableList给出错误&QUOT;无法读取0行,列-1 QUOT ;.无法找到的bug的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!