Cod*_*ile 43 database sqlite android cursor listactivity
我有一个Android ListActivity是由数据库支持Cursor通过SimpleCursorAdapter.
单击项目时,将切换数据库中相应行中的标志字段,并且需要更新列表中的视图.
问题是,当更新的视图离开屏幕并被回收时,旧视图返回到视图时会显示在视图上.每当thr list重绘时(方向更改等),都会发生同样的事情.
我notifydatasetchanged()用来刷新光标适配器,但似乎无效.
我应该如何更新数据库以便更新游标?
Com*_*are 90
打电话requery()的Cursor,当你更改了要反映在数据库中的数据Cursor(或事物的Cursor填充,如ListView通过CursorAdapter).
A Cursor类似于ODBC客户端游标 - 它包含查询结果表示的所有数据.因此,仅仅因为您更改了数据库中的数据,Cursor除非您通过它刷新,否则不会知道这些更改requery().
更新:由于年龄的原因,应该删除整个问题和一组答案,但这显然是不可能的.任何寻求Android答案的人都应该记住,Android是一个快速移动的目标,而2009年的答案通常比新答案更糟糕.
目前的解决方案是,以获得新鲜的Cursor,并使用任一changeCursor()或swapCursor()上CursorAdapter以影响数据的变化.
sie*_*fca 21
如果使用加载器和自动生成的游标,您可以调用:
getLoaderManager().restartLoader(0, null, this);
Run Code Online (Sandbox Code Playgroud)
在您的活动中,在更改DB上的内容之后,重新生成新游标.不要忘记定义事件处理程序:
@Override
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
CursorLoader cursorLoader =
new CursorLoader(this,
YOUR_URI,
YOUR_PROJECTION, null, null, null);
return cursorLoader;
}
@Override
public void onLoadFinished(Loader<Cursor> loader, Cursor data) {
adapter.swapCursor(data);
}
@Override
public void onLoaderReset(Loader<Cursor> loader) {
adapter.swapCursor(null);
}
Run Code Online (Sandbox Code Playgroud)