如何使用SQLite

http://www.cnblogs.com/xirihanlin/archive/2011/12/30/2307139.html

前些时候看到兴趣小组里有人问“Androidsqlite的最佳实践”是什么,好奇地搜了一下,确实没有一个好一点的指导文档,平时的使用也只是简单的拷贝code,并没有深入的研究过。以下是我看到的Kevin关于其使用的心得,原文的大体的意思是:

Android例子涵盖了一些sqlite的基本用法,但它们并没有深入地给出合理的使用方法,更重要的是,不合理的使用方法。大多数例子和文档只是涉及最基本的数据库查询,或者教你如何创建一个ContentProvider。从来不提及的地方像:

·什么地方创建和保存sqliteOpenHelper实例?

·可以有多少个实例?

·多线程同时访问数据库有没有什么要担心的?

基本的内容是,你可以任意次数地连接sqlite数据库,而且Android系统也支持你这样做。sqlite拥有文件级别的锁,用来同步访问和防止错误。如果你只知道这些,那么,将会给你带来很大的痛苦。开源的一个好处是,你可以深入代码一探究竟。从代码和一些测试中,我了解到以下事实:

·sqlite拥有文件级别的锁。许多线程可以同时读,但只有一个可以写。锁阻止多个同时写入。

·AndroidsqliteDatabase中实现了一些java锁来确保动作是同步进行。

·如果你用多个线程疯狂地访问数据库,你的数据库不会(或不应该)崩溃。

没提到的是,如果你通过多个不同的真实连接同时写数据库,其中的某个会失败,它不会等到前一个完成后继续写入。简单地,不会写入你的改变,更糟糕的是,你也得不到一个异常,只是在LogCat输出一些message,仅此而已。

sqliteOpenHelper类做了一些有趣的事。尽管它有方法可以获得一个只读的连接和可读写的连接,但实质上它们是同一个连接。假设没有文件错误的话,只读的连接实质上就是一个可读写的连接。有趣吧。因此,如果你的app中使用一个helper的话,即便从多线程中使用,你也从未使用多个连接。

同样,一个helper中只有一个sqliteDatabase的实例,这个实例中实现了一些java锁。因此,当你正在执行数据库的操作时,其它db的操作都将锁定。即便是你使用多个线程来做这些事以便优化数据库性能,坏消息,没有什么用。

按照我的认识,sqlite工作的方式,基本上不可能会破坏你的数据库,除非代码里有bug或者有硬件问题。

因此,我推荐这样使用:创建一个sqliteOpenHelper静态对象。什么时候去close它呢?不需要。当app关闭,它会自动释放文件引用。

但是,会不会有“close() was never explicitly called on database”异常呢?

如果你注意的话,当连接挂在那里的时候,你没有得到那个异常。你只是在连接已经建立,而你又尝试打开另一个时才会有异常。因此,你只需要打开一次连接。

像这样来使用:

public class DatabaseHelper extends OrmLitesqliteOpenHelper

{

private static DatabaseHelper instance;

public static synchronized DatabaseHelper getHelper(Context context)

{

if (instance == null)

instance = new DatabaseHelper(context);

return instance;

}

//Other stuff...

}

就这些。。。

原文地址:

http://www.touchlab.co/blog/android-sqlite-locking/

http://www.touchlab.co/blog/single-sqlite-connection/

相关文章

安装 在Windows上安装SQLite。 访问官网下载下Precompliled Binaries for Windows的两个压缩包。 创建s...
一、安装 下载地址:http://www.sqlite.org/download.html 将Precompiled Binaries for Windows下的包下...
实例: 会员信息管理 功能:1.查看数据库 2.清空数据库 3.增加会员 4.删除会员 5.更新会员 6.查找会员  ...
关于SQLite SQLite是一个轻量的、跨平台的、开源的数据库引擎,它的在读写效率、消耗总量、延迟时间和整...