本文介绍了如何让SQLite的连接更加高效的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
有什么优势,在保持本地sqlite的连接打开,该活动正在运行的全部时间?
我通常会创建一个新的连接,然后每个执行数据库操作方法内关闭。它看起来是这样的:
myMethod的(上下文的背景下){
LocalDBHelper localDBHelper =新LocalDBHelper(背景); //扩展SQLiteOpenHelper
SQLiteDatabase分贝= localDBHelper.getWritableDatabase();
...
localDBHelper.close();
}
因此,在一个典型的用户会话,这会发生大约10次。难道是有意义的创建 onResume())的连接
,使用,在所有的数据库访问方法,最后关闭它在的onPause(
解决方案
You usually want one "connection" for the entire life of your process. In particular, you do not want to have multiple "connections" in use simultaneously across multiple threads. All of the thread-safety logic for SQLite in Android is based around using a single SQLiteDatabase
(and, hence, single SQLiteOpenHelper
) for all of those threads, so proper locking can be done.
这篇关于如何让SQLite的连接更加高效的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!