android的Cursor.requery()方法过时怎么办
在android用户界面中执行了insert数据库的方法,现在的问题是,需要重新查询数据库,以在用户界面反应数据的变化(使用adapter的notifyDataSetCh...
在android用户界面中执行了insert数据库的方法,现在的问题是,需要重新查询数据库,以在用户界面反应数据的变化(使用adapter的notifyDataSetChanged()方法),有什么好方法嘛?
展开
1个回答
展开全部
Cursor.requery()方法 是过时了。如果数据量大,会导致重写读取的事件长(也就是requery()的执行时间)。在数据库数据少的时候,我们仍然可以安全地使用requery。但是对于具有大量数据时,就不建议使用了。
SimpleCursorAdapter adapter=new SimpleCursorAdapter(context, layout, cursor, from, to, flags);
当你插入数据时,参数cursor 的数据必须要变化才会更新,所以你要将cursor 从新 进行赋值(注意 cursor不是新的实例),再调用notifyDataSetChanged();
SimpleCursorAdapter adapter=new SimpleCursorAdapter(context, layout, cursor, from, to, flags);
当你插入数据时,参数cursor 的数据必须要变化才会更新,所以你要将cursor 从新 进行赋值(注意 cursor不是新的实例),再调用notifyDataSetChanged();
更多追问追答
追问
嗯。如果数据量大呢?是不是因为该方法会阻塞UI线程?有什么替代方法
追答
肯定会阻塞UI线程,你可以通过后台线程来读取数据库。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |