SQLite数据库简介

SQLite数据库简介,第1张

概述大家好,今天来介绍一下SQLite的相关知识,并结合Java实现对SQLite数据库的 *** 作。 SQLite是D.Richard Hipp用C语言编写的开源嵌入式数据库引擎。它支持大多数的SQL92标准,并且可以在所有主要的 *** 作系统上运行。 SQLite由以下几个部分组成:SQL编译器、内核、后端以及附件。SQLite通过利用虚拟机和虚拟数据库引擎(VDBE),是调试、修改和扩展SQLite的内核变

大家好,今天来介绍一下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下试验,所以我选择了@R_486_3013@ BinarIEs For windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是sqlite数据库引擎,后者是sqlite数据库分析器,主要用于分析数据库的状态等信息,大家也可以根据自己的情况去下载。下载完成后分别解压,得到两个可执行文件,如图:


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


创建数据库:

[sql] view plain copy print ? D:\>sqlite3test.db sqliteversion3.7.7.12011-06-2817:39:05 Enter".help"forinstructions Entersqlstatementsterminatedwitha";" sqlite>.databases seqnamefile ---------------------------------------------------------------------------- 0mainD:\test.db sqlite>
D:\>sqlite3 test.dbsqlite version 3.7.7.1 2011-06-28 17:39:05Enter ".help" for instructionsEnter sql statements terminated with a ";"sqlite> .databasesseq  name             file---  ---------------  ----------------------------------------------------------0    main             D:\test.dbsqlite>
我们执行了sqlite3命令,参数就是数据库的名称,如果该数据库已存在,则使用,如果不存在,则新建一个,这里我们简单的在当前位置创建了test.db,你也可以在任何存在的并且可写的目录下创建自己的数据库。(如果对于sqlite的命令不太熟悉,可以执行“.help”命令列出所有的命令清单进行查看)。


创建表:

[sql] view plain copy print ? sqlite>CREATEtableperson(IDINTEGERPRIMARYKEYautoINCREMENT,nameVARCHAR(20),ageSMALliNT); sqlite>.tables person sqlite>.schemaperson CREATEtableperson(IDINTEGERPRIMARYKEYautoINCREMENT,ageSMALliNT); sqlite>
sqlite> CREATE table person (ID INTEGER PRIMARY KEY autoINCREMENT,name VARCHAR(20),age SMALliNT);sqlite> .tablespersonsqlite> .schema personCREATE table person (ID INTEGER PRIMARY KEY autoINCREMENT,age SMALliNT);sqlite>
在我们创建表之后,可以用“.tables”命令去查看已有的表,用“.schema”命令去查看表的结构,如果后面没有表名做参数,则将会输出所有表的建表语句。


插入数据:

[sql] view plain copy print ? sqlite>INSERTINTOpersonVALUES(NulL,'john',30); sqlite>SELECT*FROMperson; 1|john|30
sqlite> INSERT INTO person VALUES (NulL,'john',30);sqlite> SELECT * FROM person;1|john|30


从.sql文件导入数据:

[sql] view plain copy print ? sqlite>.readtest.sql sqlite>SELECT*FROMperson; 1|john|30 2|davID|35 3|henry|40 sqlite>
sqlite> .read test.sqlsqlite> SELECT * FROM person;1|john|302|davID|353|henry|40sqlite>


分析数据库使用状态:

[sql] view plain copy print ? D:\>sqlite3_analyzertest.db /**disk-SpaceutilizationReportFortest.db Pagesizeinbytes....................1024 Pagesinthewholefile(measured)....4 Pagesinthewholefile(calculated)..4 Pagesthatstoredata.................4100.0% PagesonthefreeList(perheader)....00.0% PagesonthefreeList(calculated)....00.0% Pagesofauto-vacuumoverhead.........00.0% Numberoftablesinthedatabase......4 Numberofindices.....................0 Numberofnamedindices...............0 automaticallygeneratedindices.......0 Sizeofthefileinbytes.............4096 Bytesofuserpayloadstored..........390.95% ...
D:\>sqlite3_analyzer test.db/** disk-Space utilization Report For test.dbPage size in bytes.................... 1024Pages in the whole file (measured).... 4Pages in the whole file (calculated).. 4Pages that store data................. 4          100.0%Pages on the freeList (per header).... 0            0.0%Pages on the freeList (calculated).... 0            0.0%Pages of auto-vacuum overhead......... 0            0.0%Number of tables in the database...... 4Number of indices..................... 0Number of named indices............... 0automatically generated indices....... 0Size of the file in bytes............. 4096Bytes of user payload stored.......... 39           0.95%...


备份数据库:

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

[sql] view plain copy print ? sqlite>.dump PRAGMAforeign_keys=OFF; BEGINTRANSACTION; CREATEtableperson(IDINTEGERPRIMARYKEYautoINCREMENT,ageSMALliNT); INSERTINTO"person"VALUES(1,30); INSERTINTO"person"VALUES(2,'davID',35); INSERTINTO"person"VALUES(3,'henry',40); DELETEFROMsqlite_sequence; INSERTINTO"sqlite_sequence"VALUES('person',3); COMMIT; sqlite>.outputdump.sql sqlite>.dump sqlite>
sqlite> .dumpPRAGMA foreign_keys=OFF;BEGIN TRANSACTION;CREATE table person (ID INTEGER PRIMARY KEY autoINCREMENT,age SMALliNT);INSERT INTO "person" VALUES(1,30);INSERT INTO "person" VALUES(2,'davID',35);INSERT INTO "person" VALUES(3,'henry',40);DELETE FROM sqlite_sequence;INSERT INTO "sqlite_sequence" VALUES('person',3);COMMIT;sqlite> .output dump.sqlsqlite> .dumpsqlite>
我们可以指定输出的目标为一个文件,然后再使用命令时,输出信息就会写入指定的文件,如果想恢复为标准输出,可以这样设定: [sql] view plain copy print ? sqlite>.outputstdout sqlite>.dump PRAGMAforeign_keys=OFF; BEGINTRANSACTION; CREATEtableperson(IDINTEGERPRIMARYKEYautoINCREMENT,ageSMALliNT); INSERTINTO"person"VALUES(1,30); INSERTINTO"person"VALUES(2,35); INSERTINTO"person"VALUES(3,40); DELETEFROMsqlite_sequence; INSERTINTO"sqlite_sequence"VALUES('person',3); COMMIT; sqlite>
sqlite> .output stdoutsqlite> .dumpPRAGMA foreign_keys=OFF;BEGIN TRANSACTION;CREATE table person (ID INTEGER PRIMARY KEY autoINCREMENT,3);COMMIT;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代码:

[java] view plain copy print ? packagecom.scott.sqlite; importjava.sql.Connection; importjava.sql.DriverManager; importjava.sql.ResultSet; importjava.sql.Statement; publicclassTest{ publicstaticvoIDmain(String[]args)throwsException{ Class.forname("org.sqlite.JDBC"); Connectionconn=DriverManager.getConnection("jdbc:sqlite:db/test.db"); Statementstmt=conn.createStatement(); stmt.executeUpdate("DROPtableIFEXISTSperson"); stmt.executeUpdate("CREATEtableperson(IDINTEGER,nameSTRING)"); stmt.executeUpdate("INSERTINtopersonVALUES(1,'john')"); stmt.executeUpdate("INSERTINtopersonVALUES(2,'davID')"); stmt.executeUpdate("INSERTINtopersonVALUES(3,'henry')"); ResultSetrs=stmt.executequery("SELECT*FROMperson"); while(rs.next()){ System.out.println("ID=>"+rs.getInt("ID")+",name=>"+rs.getString("name")); } stmt.close(); conn.close(); } }
package com.scott.sqlite;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.Statement;public class Test {	public static voID main(String[] args) throws Exception {		Class.forname("org.sqlite.JDBC");		Connection conn = DriverManager.getConnection("jdbc:sqlite:db/test.db");		Statement stmt = conn.createStatement();		stmt.executeUpdate("DROP table IF EXISTS person");		stmt.executeUpdate("CREATE table person(ID INTEGER,name STRING)");		stmt.executeUpdate("INSERT INTO person VALUES(1,'john')");		stmt.executeUpdate("INSERT INTO person VALUES(2,'davID')");		stmt.executeUpdate("INSERT INTO person VALUES(3,'henry')");		ResultSet rs = stmt.executequery("SELECT * FROM person");		while (rs.next()) {			System.out.println("ID=>" + rs.getInt("ID") + ",name=>" + rs.getString("name"));		}		stmt.close();		conn.close();	}}
执行Test.java文件,结果如下:


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



sqlite使用须知:

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

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

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


结束语:

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

总结

以上是内存溢出为你收集整理的SQLite数据库简介全部内容,希望文章能够帮你解决SQLite数据库简介所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1182005.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存