原文地址:http://blog.csdn.net/liuhe688/article/details/6712782
本文做了相关编辑、整理,感谢原作者;
在操作之前,朋友们要先下载sqlite数据库,官方的下载页面是http://sqlite.org/download.html,我是在Windows下试验,所以我选择了Precompiled Binaries For Windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是sqlite数据库引擎,后者是sqlite数据库分析器,主要用于分析数据库的状态等信息,大家也可以根据自己的情况去下载。下载完成后分别解压,得到两个可执行文件,如图:
这两个文件可以根据自己的喜好放置在指定的位置,我将其放在D盘根目录下。下面我们就来一步一步操作sqlite:
创建数据库:
创建表:
插入数据:
分析数据库使用状态:
- 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%
- ...
备份数据库:
备份 sqlite 数据库有两种方法。如果数据库正在使用中,则应从命令行界面使用 .dump 命令。这样可以创建一个包含必要命令和数据的文件,从而重新创建数据库。.dump 命令也可以用于备份数据库表。
- 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>.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>
如果数据库没有处于使用状态,则可以直接将数据库文件复制到安全位置。
最后,我们可以使用“.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代码:
- 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();
- }
- }
这个时候,在我们的db目录下,就生成了一个test.db的文件:
sqlite使用须知:
目前没有可用于 sqlite 的网络服务器。从应用程序运行位于其他计算机上的 sqlite 的惟一方法是从网络共享运行。这样会导致一些问题,像 UNIX® 和 Windows® 网络共享都存在文件锁定问题。还有由于与访问网络共享相关的延迟而带来的性能下降问题。
sqlite 没有用户帐户概念,而是根据文件系统确定所有数据库的权限。
结束语:
由于资源占用少、性能良好和零管理成本,嵌入式数据库有了它的用武之地,像Android、iPhone都有内置的sqlite数据库供开发人员使用,它的易用性可以加快应用程序的开发,并使得复杂的数据存储变得轻松了许多。
原文链接:https://www.f2er.com/sqlite/200848.html