大家好,今天来介绍一下SQLite的相关知识,并结合Java实现对SQLite数据库的操作。

SQLite是D.Richard Hipp用C语言编写的开源嵌入式数据库引擎。它支持大多数的SQL92标准,并且可以在所有主要的操作系统上运行。

SQLite由以下几个部分组成:SQL编译器、内核、后端以及附件。SQLite通过利用虚拟机和虚拟数据库引擎(VDBE),是调试、修改和扩 展SQLite的内核变得更加方便。所有SQL语句都被编译成易读的、可以在SQLite虚拟机中执行的程序集。SQLite的整体结构图如下:

值得一提的是,袖珍型的SQLite竟然可以支持高达2TB大小的数据库,每个数据库都是以单个文件的形式存在,这些数据都是以B-Tree的数据结构形式存储在磁盘上。

在事务处理方面,SQLite通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但只有一
个可以写入数据。在某个进程或线程想数据库执行写操作之前,必须获得独占锁。在获得独占锁之后,其他的读或写操作将不会再发生。

SQLite采用动态数据类型,当某个值插入到数据库时,SQLite将会检查它的类型,如果该类型与关联的列不匹配,SQLite则会尝试将该值
转换成该列的类型,如果不能转换,则该值将作为本身的类型存储,SQLite称这为“弱类型”。但有一个特例,如果是INTEGER PRIMARY
KEY,则其他类型不会被转换,会报一个“datatype missmatch”的错误。

概括来讲,SQLite支持NULL、INTEGER、REAL、TEXT和BLOB数据类型,分别代表空值、整型值、浮点值、字符串文本、二进制对象。

下面,我们就来亲自操作一下SQLite数据库。

在操作之前,朋友们要先下载SQLite数据库,官方的下载页面是http://sqlite.org/download.html
我是在Windows下试验,所以我选择了Precompiled Binaries For
Windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是
SQLite数据库引擎,后者是SQLite数据库分析器,主要用于分析数据库的状态等信息,大家也可以根据自己的情况去下载。下载完成后分别解压,得到
两个可执行文件,如图:

这两个文件可以根据自己的喜好放置在指定的位置,我将其放在D盘根目录下。下面我们就来一步一步操作SQLite:


创建数据库:

  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. 0    main             D:\test.db
  9. sqlite>


们执行了sqlite3命令,参数就是数据库的名称,如果该数据库已存在,则使用,如果不存在,则新建一个,这里我们简单的在当前位置创建了
test.db,你也可以在任何存在的并且可写的目录下创建自己的数据库。(如果对于SQLite的命令不太熟悉,可以执行“.help”命令列出所有的
命令清单进行查看)。


创建表:

  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”命令去查看表的结构,如果后面没有表名做参数,则将会输出所有表的建表语句。


插入数据:

  1. sqlite> INSERT INTO person VALUES (NULL, 'john', 30);
  2. sqlite> SELECT * FROM person;
  3. 1|john|30


从.sql文件导入数据:

  1. sqlite> .read test.sql
  2. sqlite> SELECT * FROM person;
  3. 1|john|30
  4. 2|david|35
  5. 3|henry|40
  6. sqlite>


分析数据库使用状态:

  1. D:\>sqlite3_analyzer test.db
  2. /** Disk-Space Utilization Report For test.db
  3. Page size in bytes.................... 1024
  4. Pages in the whole file (measured).... 4
  5. Pages in the whole file (calculated).. 4
  6. Pages that store data................. 4          100.0%
  7. Pages on the freelist (per header).... 0            0.0%
  8. Pages on the freelist (calculated).... 0            0.0%
  9. Pages of auto-vacuum overhead......... 0            0.0%
  10. Number of tables in the database...... 4
  11. Number of indices..................... 0
  12. Number of named indices............... 0
  13. Automatically generated indices....... 0
  14. Size of the file in bytes............. 4096
  15. Bytes of user payload stored.......... 39           0.95%
  16. ...


备份数据库:

备份 SQLite 数据库有两种方法。如果数据库正在使用中,则应从命令行界面使用 .dump 命令。这样可以创建一个包含必要命令和数据的文件,从而重新创建数据库。.dump 命令也可以用于备份数据库表。

  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>

我们可以指定输出的目标为一个文件,然后再使用命令时,输出信息就会写入指定的文件,如果想恢复为标准输出,可以这样设定:

  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管理工具很多,我向大家推荐一款好用的工具:SQLite Expert。


在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代码:

  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. public class Test {
  7. public static void main(String[] args) throws Exception {
  8. Class.forName("org.sqlite.JDBC");
  9. Connection conn = DriverManager.getConnection("jdbc:sqlite:db/test.db");
  10. Statement stmt = conn.createStatement();
  11. stmt.executeUpdate("DROP TABLE IF EXISTS person");
  12. stmt.executeUpdate("CREATE TABLE person(id INTEGER, name STRING)");
  13. stmt.executeUpdate("INSERT INTO person VALUES(1, 'john')");
  14. stmt.executeUpdate("INSERT INTO person VALUES(2, 'david')");
  15. stmt.executeUpdate("INSERT INTO person VALUES(3, 'henry')");
  16. ResultSet rs = stmt.executeQuery("SELECT * FROM person");
  17. while (rs.next()) {
  18. System.out.println("id=>" + rs.getInt("id") + ", name=>" + rs.getString("name"));
  19. }
  20. stmt.close();
  21. conn.close();
  22. }
  23. }

执行Test.java文件,结果如下:

这个时候,在我们的db目录下,就生成了一个test.db的文件:


SQLite使用须知:

目前没有可用于 SQLite 的网络服务器。从应用程序运行位于其他计算机上的 SQLite
的惟一方法是从网络共享运行。这样会导致一些问题,像 UNIX® 和 Windows®
网络共享都存在文件锁定问题。还有由于与访问网络共享相关的延迟而带来的性能下降问题。

SQLite 只提供数据库级的锁定。

SQLite 没有用户帐户概念,而是根据文件系统确定所有数据库的权限。


结束语:

由于资源占用少、性能良好和零管理成本,嵌入式数据库有了它的用武之地,像Android、iPhone都有内置的SQLite数据库供开发人员使用,它的易用性可以加快应用程序的开发,并使得复杂的数据存储变得轻松了许多

Android SQLite (一) 数据库简介的更多相关文章

  1. Android sqlite管理数据库基本用法

    Android操作系统中内置了sqlite数据库(有关sqlite数据库详细介绍见:http://zh.wikipedia.org/wiki/SQLite),而sqllite本身是一个很小型的数据库, ...

  2. android SQLite(安卓数据库的插入显示删除)

    1.利用android自带数据库实现增加.删除.显示用户等操作 只是一个基本模型,为即将的与 复利计算apk整合做牺牲. 就不上传百度云供大家下载了 等整合了复利计算再上传. 数据的插入和显示:   ...

  3. android: SQLite创建数据库

    SQLite 是一款轻量级的关系型数据库,它的运算速度非常快, 占用资源很少,通常只需要几百 K 的内存就足够了,因而特别适合在移动设备上使用.SQLite 不仅支持标准的 SQL 语法,还遵循了数据 ...

  4. *.db-journal 是什么(android sqlite )数据库删除缓存

    sqlite的官方文档,发现该文件是sqlite的一个临时的日志文件,主要用于sqlite数据库的事务回滚操作了.在事务开始时产生,在事务操作完毕时自动删除,当程序发生崩溃或一些意外情况让程序非法结束 ...

  5. Android SQLite轻量级数据库的删除和查找操作

    今天主要是补充昨天的内容,本打算合成一章的,但是毕竟一天一天的内容写习惯了. 就这样继续昨天的,昨天只讲了创建以及增加和查询, 其实用法都差不多,今天学长也是在原有的基础上写的,还顺便融合了Share ...

  6. Android SQLite轻量级数据库(简单介绍)

    SQLite它是相当于嵌入到安卓里的一个小数据库吧, 它也可以使用SQL语句进行数据库的增删改查操作,但是是SQL1992的语句. 然后SQLite也有自己的语句,但是学过SQL的应该都会发现,它比较 ...

  7. sqlite嵌入式数据库简介及特性

    p.p1 { margin: 0; font: 12px "Helvetica Neue"; color: rgba(69, 69, 69, 1) } p.p2 { margin: ...

  8. android: SQLite升级数据库

    如果你足够细心,一定会发现 MyDatabaseHelper 中还有一个空方法呢!没错,onUpgrade() 方法是用于对数据库进行升级的,它在整个数据库的管理工作当中起着非常重要的作用,可 千万不 ...

  9. android中清空一个表---类似truncate table 表名 这样的功能 android sqlite 清空数据库的某个表

    public void clearFeedTable(){ String sql = "DELETE FROM " + FEED_TABLE_NAME +";" ...

随机推荐

  1. [原创]html5_PC游戏_图片俄罗斯方块

    PC游戏_图片俄罗斯方块 以前的了,快一年了... 使用了离线canvas复制的方法,启动预览效果需要服务器支持 另外,AC娘图片可以自己做加载功能,这样游戏图片显示更顺畅 效果: --- 代码: h ...

  2. CSS之绝对定位那些事

    1.垂直居中 有时我们会使用margin: 0 auto;作居中使用.但有的时候我们需要垂直居中,例如在div里面垂直居中显示一张加载中的gif图. 下面这种写法就可以完美实现: 垂直居中的子容器 { ...

  3. vsphere vcenter server下安装ubuntu的vmwaretools

    0.参考文献 百度经验:这里面是以redhat桌面版为实例进行介绍的,我的环境是ubuntu-server,虽然不一样,也可以参考 http://jingyan.baidu.com/article/2 ...

  4. iOS常用第三方库之Masonry

    有更新,请往最下边查看. 一.前言 关于苹果的布局一直是我比较纠结的问题,是写代码来控制布局,还是使用storyboard来控制布局呢?以前我个人开发的时候很少使用代码去写约束,因为太麻烦了.所以最终 ...

  5. iOS单元测试1

    iOS单元测试1 iOS单元测试分为两种类型的测试: 应用测试.应用程序测试可以检查app的代码组件,比如计算机的算术运算的例子.你可以利用应用程序测试来确保你的UI空间控件保持原有位置,并且你的控件 ...

  6. iOS图像资源Images Assets

    1. 在工程中单击并打开导航区域中的Images.xcassets,看看都有些什么东东:]: 2. 在图中可以看到中间位置有两个虚线框,感觉应该可以直接拖文件进来.OK,那就先准备一下资源文件,如下图 ...

  7. MJExtension简介

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  8. Android平台二维码之生成,扫描 & 识别

    1.二维码的前世今生 “二维条码/二维码(2-dimensional bar code)是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的:在代码编制上巧妙地利 ...

  9. PMP 项目管理过程组与知识领域

  10. centos查看硬件信息

    服务器硬件信息常见, 是经常要操作的事: 下面分享一些常见的硬件查看命令: 1.centos 下查看硬件信息内容非常全面. CentOS常用命令查看cpu more /proc/cpuinfo 2.C ...