Android中SQLite应用详解.docx
- 文档编号:7836485
- 上传时间:2023-01-26
- 格式:DOCX
- 页数:30
- 大小:206.98KB
Android中SQLite应用详解.docx
《Android中SQLite应用详解.docx》由会员分享,可在线阅读,更多相关《Android中SQLite应用详解.docx(30页珍藏版)》请在冰豆网上搜索。
Android中SQLite应用详解
SQLite是D.RichardHipp用C语言编写的开源嵌入式数据库引擎。
它支持大多数的SQL92标准,并且可以在所有主要的操作系统上运行。
SQLite由以下几个部分组成:
SQL编译器、内核、后端以及附件。
SQLite通过利用虚拟机和虚拟数据库引擎(VDBE),是调试、修改和扩展SQLite的内核变得更加方便。
所有SQL语句都被编译成易读的、可以在SQLite虚拟机中执行的程序集。
SQLite的整体结构图如下:
值得一提的是,袖珍型的SQLite竟然可以支持高达2TB大小的数据库,每个数据库都是以单个文件的形式存在,这些数据都是以B-Tree的数据结构形式存储在磁盘上。
在事务处理方面,SQLite通过数据库级上的独占性和共享锁来实现独立事务处理。
这意味着多个进程可以在同一时间从同一数据库读取数据,但只有一个可以写入数据。
在某个进程或线程想数据库执行写操作之前,必须获得独占锁。
在获得独占锁之后,其他的读或写操作将不会再发生。
SQLite采用动态数据类型,当某个值插入到数据库时,SQLite将会检查它的类型,如果该类型与关联的列不匹配,SQLite则会尝试将该值转换成该列的类型,如果不能转换,则该值将作为本身的类型存储,SQLite称这为“弱类型”。
但有一个特例,如果是INTEGERPRIMARYKEY,则其他类型不会被转换,会报一个“datatypemissmatch”的错误。
概括来讲,SQLite支持NULL、INTEGER、REAL、TEXT和BLOB数据类型,分别代表空值、整型值、浮点值、字符串文本、二进制对象。
下面,我们就来亲自操作一下SQLite数据库。
在操作之前,朋友们要先下载SQLite数据库,官方的下载页面是http:
//sqlite.org/download.html,我是在Windows下试验,所以我选择了PrecompiledBinariesForWindows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是SQLite数据库引擎,后者是SQLite数据库分析器,主要用于分析数据库的状态等信息,大家也可以根据自己的情况去下载。
下载完成后分别解压,得到两个可执行文件,如图:
这两个文件可以根据自己的喜好放置在指定的位置,我将其放在D盘根目录下。
下面我们就来一步一步操作SQLite:
创建数据库:
[sql] viewplaincopy
1.D:
\>sqlite3 test.db
2.SQLite version 3.7.7.1 2011-06-28 17:
39:
05
3.Enter ".help" for instructions
4.Enter SQL statements terminated with a ";"
5.sqlite> .databases
6.seq name file
7.
8.--- --------------- ----------------------------------------------------------
9.
10.0 main D:
\test.db
11.
12.sqlite>
我们执行了sqlite3命令,参数就是数据库的名称,如果该数据库已存在,则使用,如果不存在,则新建一个,这里我们简单的在当前位置创建了test.db,你也可以在任何存在的并且可写的目录下创建自己的数据库。
(如果对于SQLite的命令不太熟悉,可以执行“.help”命令列出所有的命令清单进行查看)。
创建表:
[sql] viewplaincopy
1.sqlite> CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);
2.sqlite> .tables
3.person
4.sqlite> .schema person
5.CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);
6.sqlite>
在我们创建表之后,可以用“.tables”命令去查看已有的表,用“.schema”命令去查看表的结构,如果后面没有表名做参数,则将会输出所有表的建表语句。
插入数据:
[sql] viewplaincopy
1.sqlite> INSERT INTO person VALUES (NULL, 'john', 30);
2.sqlite> SELECT * FROM person;
3.1|john|30
从.sql文件导入数据:
[sql] viewplaincopy
1.sqlite> .read test.sql
2.sqlite> SELECT * FROM person;
3.1|john|30
4.2|david|35
5.3|henry|40
6.sqlite>
分析数据库使用状态:
[sql] viewplaincopy
1.D:
\>sqlite3_analyzer test.db
2./** Disk-Space Utilization Report For test.db
3.
4.Page size in bytes.................... 1024
5.Pages in the whole file (measured).... 4
6.Pages in the whole file (calculated).. 4
7.Pages that store data................. 4 100.0%
8.Pages on the freelist (per header).... 0 0.0%
9.Pages on the freelist (calculated).... 0 0.0%
10.Pages of auto-vacuum overhead......... 0 0.0%
11.Number of tables in the database...... 4
12.Number of indices..................... 0
13.Number of named indices............... 0
14.Automatically generated indices....... 0
15.Size of the file in bytes............. 4096
16.Bytes of user payload stored.......... 39 0.95%
17....
备份数据库:
备份SQLite数据库有两种方法。
如果数据库正在使用中,则应从命令行界面使用.dump命令。
这样可以创建一个包含必要命令和数据的文件,从而重新创建数据库。
.dump命令也可以用于备份数据库表。
[sql] viewplaincopy
1.sqlite> .dump
2.PRAGMA foreign_keys=OFF;
3.BEGIN TRANSACTION;
4.CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);
5.INSERT INTO "person" VALUES(1,'john',30);
6.INSERT INTO "person" VALUES(2,'david',35);
7.INSERT INTO "person" VALUES(3,'henry',40);
8.DELETE FROM sqlite_sequence;
9.INSERT INTO "sqlite_sequence" VALUES('person',3);
10.COMMIT;
11.sqlite> .output dump.sql
12.sqlite> .dump
13.sqlite>
我们可以指定输出的目标为一个文件,然后再使用命令时,输出信息就会写入指定的文件,如果想恢复为标准输出,可以这样设定:
[sql] viewplaincopy
1.sqlite> .output stdout
2.sqlite> .dump
3.PRAGMA foreign_keys=OFF;
4.BEGIN TRANSACTION;
5.CREATE TABLE person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age SMALLINT);
6.INSERT INTO "person" VALUES(1,'john',30);
7.INSERT INTO "person" VALUES(2,'david',35);
8.INSERT INTO "person" VALUES(3,'henry',40);
9.DELETE FROM sqlite_sequence;
10.INSERT INTO "sqlite_sequence" VALUES('person',3);
11.COMMIT;
12.sqlite>
如果数据库没有处于使用状态,则可以直接将数据库文件复制到安全位置。
最后,我们可以使用“.quit”或“.exit”退出SQLite。
管理工具:
现在网络上的SQLite管理工具很多,我向大家推荐一款好用的工具:
SQLiteExpert。
在Java中使用SQLite:
我们要想在Java中使用SQLite,需要下载SQLite相关驱动,推荐大家到http:
//www.xerial.org/trac/Xerial/wiki/SQLiteJDBC页面去下载最新的驱动包,现在最新版本是sqlite-jdbc-3.7.2.jar,体积有点大,因为它包含了Linux、Mac、Windows的本地类库,如图:
下载了驱动之后,我们新建一个项目,名为sqlite:
在上图中,我们引入sqlite驱动包到类路径下,然后建立一个db的文件夹,用于放置数据库文件。
最后我们看一下Test.java代码:
[java] viewplaincopy
1.package com.scott.sqlite;
2.import java.sql.Connection;
3.import java.sql.DriverManager;
4.import java.sql.ResultSet;
5.import java.sql.Statement;
6.
7.public class Test {
8. public static void main(String[] args) throws Exception {
9. Class.forName("org.sqlite.JDBC");
10. Connection conn = DriverManager.getConnection("jdbc:
sqlite:
db/test.db");
11. Statement stmt = conn.createStatement();
12.
13. stmt.executeUpdate("DROP TABLE IF EXISTS person");
14. stmt.executeUpdate("CREATE TABLE person(id INTEGER, name STRING)");
15. stmt.executeUpdate("INSERT INTO person VALUES(1, 'john')");
16. stmt.executeUpdate("INSERT INTO person VALUES(2, 'david')");
17. stmt.executeUpdate("INSERT INTO person VALUES(3, 'henry')");
18. ResultSet rs = stmt.executeQuery("SELECT * FROM person");
19. while (rs.next()) {
20. System.out.println("id=>" + rs.getInt("id") + ", name=>" + rs.getString("name"));
21. }
22. stmt.close();
23. conn.close();
24. }
25.}
执行Test.java文件,结果如下:
这个时候,在我们的db目录下,就生成了一个test.db的文件:
SQLite使用须知:
目前没有可用于SQLite的网络服务器。
从应用程序运行位于其他计算机上的SQLite的惟一方法是从网络共享运行。
这样会导致一些问题,像UNIX®和Windows®网络共享都存在文件锁定问题。
还有由于与访问网络共享相关的延迟而带来的性能下降问题。
SQLite只提供数据库级的锁定。
SQLite没有用户帐户概念,而是根据文件系统确定所有数据库的权限。
上次我向大家介绍了SQLite的基本信息和使用过程,相信朋友们对SQLite已经有所了解了,那今天呢,我就和大家分享一下在Android中如何使用SQLite。
现在的主流移动设备像Android、iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上的SQLite开发技巧。
对于Android平台来说,系统内置了丰富的API来供开发人员操作SQLite,我们可以轻松的完成对数据的存取。
下面就向大家介绍一下SQLite常用的操作方法,为了方便,我将代码写在了Activity的onCreate中:
[java] viewplaincopy
1. @Override
2. protected void onCreate(Bundle savedInstanceState) {
3. super.onCreate(savedInstanceState);
4.
5. //打开或创建test.db数据库
6. SQLiteDatabase db = openOrCreateDatabase("test.db", Context.MODE_PRIVATE, null);
7. db.execSQL("DROP TABLE IF EXISTS person");
8. //创建person表
9. db.execSQL("CREATE TABLE person (_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR, age SMALLINT)");
10. Person person = new Person();
11. person.name = "john";
12. person.age = 30;
13. //插入数据
14. db.execSQL("INSERT INTO person VALUES (NULL, ?
?
)", new Object[]{person.name, person.age});
15.
16. person.name = "david";
17. person.age = 33;
18. //ContentValues以键值对的形式存放数据
19. ContentValues cv = new ContentValues();
20. cv.put("name", person.name);
21. cv.put("age", person.age);
22. //插入ContentValues中的数据
23. db.insert("person", null, cv);
24.
25. cv = new ContentValues();
26. cv.put("age", 35);
27. //更新数据
28. db.update("person", cv, "name = ?
", new String[]{"john"});
29.
30. Cursor c = db.rawQuery("SELECT * FROM person WHERE age >= ?
", new String[]{"33"});
31. while (c.moveToNext()) {
32. int _id = c.getInt(c.getColumnIndex("_id"));
33. String name = c.getString(c.getColumnIndex("name"));
34. int age = c.getInt(c.getColumnIndex("age"));
35. Log.i("db", "_id=>" + _id + ", name=>" + name + ", age=>" + age);
36. }
37. c.close();
38.
39. //删除数据
40. db.delete("person", "age < ?
", new String[]{"35"});
41.
42. //关闭当前数据库
43. db.close();
44.
45. //删除test.db数据库
46.// deleteDatabase("test.db");
47. }
在执行完上面的代码后,系统就会在/data/data/[PACKAGE_NAME]/databases目录下生成一个“test.db”的数据库文件,如图:
上面的代码中基本上囊括了大部分的数据库操作;对于添加、更新和删除来说,我们都可以使用
[java] viewplaincopy
1.db.executeSQL(String sql);
2.db.executeSQL(String sql, Object[] bindArgs);//sql语句中使用占位符,然后第二个参数是实际的参数集
除了统一的形式之外,他们还有各自的操作方法:
[java] viewplaincopy
1.db.insert(String table, String nullColumnHack, ContentValues values);
2.db.update(String table, Contentvalues values, String whereClause, String whereArgs);
3.db.delete(String table, String whereClause, String whereArgs);
以上三个方法的第一个参数都是表示要操作的表名;insert中的第二个参数表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为NULL,不至于出现错误;insert中的第三个参数是ContentValues类型的变量,是键值对组成的Map,key代表列名,value代表该列要插入的值;update的第二个参数也很类似,只不过它是更新该字段key为最新的value值,第三个参数whereClause表示WHERE表达式,比如“age>?
andage
”等,最后的whereArgs参数是占位符的实际参数值;delete方法的参数也是一样。
下面来说说查询操作。
查询操作相对于上面的几种操作要复杂些,因为我们经常要面对着各种各样的查询条件,所以系统也考虑到这种复杂性,为我们提供了较为丰富的查询形式:
[java] viewplaincopy
1.db.rawQuery(String sql, String[] selectionArgs);
2.db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy);
3.db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);
4.db.query(String distinct, String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);
上面
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Android SQLite 应用 详解