android – 从SQLite数据库中显示ListView中的100000个项目
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了android – 从SQLite数据库中显示ListView中的100000个项目,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1724字,纯文字阅读大概需要3分钟。
内容图文
![android – 从SQLite数据库中显示ListView中的100000个项目](/upload/InfoBanner/zyjiaocheng/898/0c5154f97da1429c9e554b5675a70677.jpg)
我正在尝试使用游标在ListView中显示预填充数据库(超过100000行)中的所有项目.它可以工作,但是应用程序启动并显示ListView需要几分钟的时间.有更快的方法吗?我读过有关FTS3表的内容,会有帮助吗?
我正在使用ArrayList< HashMap< String,String>>使用SimpleAdapter和自定义2行布局.
码:
Cursor cursor = sDictionary.query("FTSgesla", new String[] {PodatkovnaBaza.KEY_WORD, PodatkovnaBaza.KEY_DEFINITION}, null, null, null, null, PodatkovnaBaza.KEY_WORD);
if (cursor == null)
{
// There are no results
mTextView.setText("Empty");
}
else
{
HashMap<String, String> item;
if(cursor.moveToFirst())
{
do
{
item = new HashMap<String, String>();
item.put("line1", cursor.getString(0));
item.put("line2", cursor.getString(1));
list.add(item);
}
while(cursor.moveToNext());
}
sa = new SimpleAdapter(GlavniActivity.this, list,
R.layout.result,
new String[] { "line1","line2" },
new int[] {R.id.word, R.id.definition});
mListView.setAdapter(sa);
// Define the on-click listener for the list items
mListView.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//do something
}
});
}
解决方法:
没有更快的方法来加载100000个项目,并且您的用户也不需要同时查看所有项目,因此,使用线程逐个加载它们.
private class SQLTask extends AsyncTask<Integer, String[], Integer> {
@Override
protected Integer doInBackground(Integer... params) {
db.open();
Cursor c = db.getAllDataCursor();
for (c.moveToFirst(); !c.isAfterLast(); c.moveToNext()) {
String[] temp = new String[c.getColumnCount()];
for (int i = 0; i < temp.length; i++) {
temp[i] = c.getString(i);
}
publishProgress(thisTask, temp);
}
c.close();
db.close();
}
@Override
protected void onProgressUpdate(String[]... values) {
super.onProgressUpdate(values);
// LOAD ONE ROW
}
}
内容总结
以上是互联网集市为您收集整理的android – 从SQLite数据库中显示ListView中的100000个项目全部内容,希望文章能够帮你解决android – 从SQLite数据库中显示ListView中的100000个项目所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。