安卓加载mysql数据到列表里_Android如何从数据库中加载海量数据

这篇博客探讨了在Android 3.0之前一次性从数据库加载大量数据到ListView的问题,以及从3.0版本开始引入的Loader机制。文章通过一个示例展示了如何使用CursorLoader的子类SQLiteCursorLoader来实现从SQLite数据库中高效加载数据,同时指出ContentProvider并非总是必要的,可以直接使用SQLite查询。此外,还提到了使用ORM框架简化数据库操作的可能性。
摘要由CSDN通过智能技术生成

在Android3.0之前,很多应用程序响应性能方面有缺陷,其中比较典型的错误行为是在UI线程中执行了查询数据操作,尤其是一次性从database查出大量数据并加载到ListView里,用这种方式载入数据是最差的选择,硬件偏弱的手机会假死会儿。 其实体验最好的还属手机自带通讯录App这类应用,滑动丝般顺滑。

在Android 3.0版本之前一般的做法是用Activity提供的startManagingCursor()和stopManagingCursor(),  已经deprecated的API我们就不谈了,3.0之后取而代之的是Loader,想必Loader的使用大家都有所知道:public class CursorLoaderListFragment extends ListFragment {

SimpleCursorAdapter mAdapter;

SearchView mSearchView;

String mCurFilter;    static final String[] CONTACTS_SUMMARY_PROJECTION = new String[] {

ContactsContract.Contacts._ID,

ContactsContract.Contacts.DISPLAY_NAME,

ContactsContract.Contacts.CONTACT_STATUS,

};    private LoaderManager.LoaderCallbacks mLoaderCallback = new LoaderManager.LoaderCallbacks() {        @Override

public Loader onCreateLoader(int id, Bundle args) {            // This is called when a new Loader needs to be created.

String select = "((" + ContactsContract.Contacts.DISPLAY_NAME + " NOTNULL) AND ("

+ ContactsContract.Contacts.HAS_PHONE_NUMBER + "=1) AND ("

+ ContactsContract.Contacts.DISPLAY_NAME + " != '' ))";            return new CursorLoader(getActivity(),

ContactsContract.Contacts.CONTENT_URI,

CONTACTS_SUMMARY_PROJECTION, select, null,

ContactsContract.Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC");

}        @Override

public void onLoadFinished(@NonNull Loader loader, Cursor data) {            //

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值