SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能。此外它还是开源的,任何人都可以使用它。许多开源项目((Mozilla, PHP, Python)都使用了 SQLite.
Android 开发中使用 SQLite 数据库
Activites 可以通过 Content Provider 或者 Service 访问一个数据库。下面会详细讲解如果创建数据库,添加数据和查询数据库。
创建数据库
Android 不自动提供数据库。在 Android 应用程序中使用 SQLite,必须自己创建数据库,然后创建表、索引,填充数据。Android 提供了 SQLiteOpenHelper 帮助你创建一个数据库,你只要继承 SQLiteOpenHelper 类,就可以轻松的创建数据库。SQLiteOpenHelper 类根据开发应用程序的需要,封装了创建和更新数据库使用的逻辑。SQLiteOpenHelper 的子类,至少需要实现三个方法:
构造函数,调用父类 SQLiteOpenHelper 的构造函数。这个方法需要四个参数:上下文环境(例如,一个 Activity),数据库名字,一个可选的游标工厂(通常是 Null),一个代表你正在使用的数据库模型版本的整数。
onCreate()方法,它需要一个 SQLiteDatabase 对象作为参数,根据需要对这个对象填充表和初始化数据。
onUpgrage() 方法,它需要三个参数,一个 SQLiteDatabase 对象,一个旧的版本号和一个新的版本号,这样你就可以清楚如何把一个数据库从旧的模型转变到新的模型。
在Android中操作SQLite数据库使用SQLiteDatabase类,使用该类可以对数据库进行添加(Create)、查询(Retrieve)、更新(Update)和删除(Delete)操作。需要重点掌握的是execSQL()和rawQuery()方法。其中 execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句; rawQuery()方法用于执行select语句。
举一例说明execSQL()使用方法:
SQLiteDatabase mydb = ....;
mydb.execSQL("insert into person(name, age) values('网虫一族', 23)");
mydb.close();
从上面简单的例子可以看出,SQLiteDatabase执行的是标准的SQL语句,所以,并不需要额外掌握更多的知识,在帮助文档中熟悉下SQLiteDatabase类的几个方法就可以了。
有两种方法:
一种是把sqlite数据库的源代码(C/c++)编译到你的App中,利用API操作数据库,这种方法需要C/C++开发App;还可以把sqlite数据库的源代码编译成动态链接库,在其他语言的APP中调用。
另一种办法是使用继集成了sqlite数据库驱动的系统开发,例如RAD Studio Seattle以后的版本,包括delphi/c++ bulider两种开发工具,可以使用C++/Object Pascal语言进行开发,这个集成环境使用很方便。