JAVA在SQLite 嵌入式数据库中的应用
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
JAVA在SQLite嵌入式数据库中的应用
王冠宇关永赵冬生
(首都师范大学信息工程学院北京100037E-MAIL:wgy823@)
摘要SQLite作为一个开源的嵌入式数据库产品,具有系统开销小,检索效率高的特性,
适用于手机、PDA、机顶盒设备等电器,并且作为嵌入式数据库在可下载的消费类应用程序中
运行的很好。这篇文章介绍嵌入式数据库产品SQLite的技术特点,并着重讨论研究与Java
语言之间的接口,并以实例说明如何使用JAVA开发基于SQLite的应用程序。
关键词嵌入式数据库;SQLITE;JAVA;JNI接口;JDBC驱动程序
中图分类号TP331.13文献标识码A
基金资助项目:国家863项目编号:2002AA714023
Application of JAVA in The SQLite
Embedded Database
WANG Guan-yu GUAN Yong
(Information engineering college,capital normal university,Beijing
100037E-MAIL:wgy823@)
Abstract SQLite,which has the features of less code and faster searching speed,is a product of open-source embedded database. SQLite is a good fit for use in cell phones,PDAs,set-top boxes,
and/or appliances.It also works well as an embedded database in downloadable consumer applications.This article introduces the features of SQLite,and put emphasis on the study of the JAVA interface with SQLite,at last demonstrates how to develop the application based on SQLite in JAVA.
Key words embedded database,SQLite,JAVA,JNI interface,JDBC driver
1引言
通常我们采用各种数据库产品来实现对数据的存储、检索等功能,例如,Oracle,SQL Server,MySQL等等。这些产品除提供基本的查询,删除,添加等功能外,也提供了很多高级特性,如触发
器,存储过程,数据备份恢复,全文检索功能等。但实际上,很多的应用,仅仅利用到了这些数据库产品的基本特性而已。而且在一些小型应用上,或者某些特殊场合的应用,比如桌面程序,这些数据库产品就明显有一些臃肿。在这些情况下,嵌入式数据库的优势就特别明显了。
嵌入式数据库无须独立运行的数据库引擎,它是由程序直接调用相应的API去实现对数据的存取操作。更直白的讲,嵌入式数据库是一种具备了基本数据库特性的数据文件。嵌入式数据库与其它数据库产品的区别是,前者是程序驱动式,而后者是引擎响应式。嵌入式数据库的一个很重要的特点是它们的体积非常小,编译后的产品也不过几十K。这不但对桌面程序的数据存储方案是一个很好的选择,也使得它们可以应用到一些移动设备上。同时,很多嵌入式数据库在性能上也优于其它数据库,所以在高性能的应用上也常见嵌入式数据库的身影。
下面介绍的是开放源代码的嵌入式数据库,SQLite。同时侧重研究如何应用Java连接SQLite 数据库,并开发基于SQLite的应用程序。
---------------------------
收稿日期:
2SQLite简介
SQLite是D·理查德·希普开发出来的用一个小型C库实现的一种强有力的嵌入式关系数据库管理体制。它提供了对SQL92的大多数支持:支持多表和索引、事务、视图、触发和一系列的用户接口及驱动[1]。
SQLite实现了完备的、可嵌入的、零配置的SQL数据库引擎。它的特点包括[2]:
1.事务处理是原子的、一致的、独立的和持久的(ACID),即使在系统崩溃和掉电以后。
2.零配置,即不需要设置和管理。
3.实现了绝大部分的SQL92标准。
4.一个单独的磁盘文件存储一个完整的数据库。
5.数据库文件在机器之间可自由共享。
6.支持数据库文件大小至2TB.
7.字符串和BLOG的大小只受限于可用存储器容量。
8.代码量小,即小于30K的C代码行和小于250K的代码空间(gcc在i486上)
9.对于绝大多数普通操作来说,比流行的C/S模式的数据库引擎运行速度快。
10.API简单、易用。
可以看出,基于以上特点,SQLite非常适合应用于嵌入式移动数据库。SQLite的版权允许无任何限制的应用,包括商业性的产品。SQLite官方主站上可以下载到编译后的SQLite程序。3建立SQLite数据库
SQLite是无数据类型的数据库。虽然在生成表结构的时候,要声明每个域的数据类型,但SQLite并不做任何检查。开发人员要靠自己的程序控制输入与读出数据的类型是正确的。这里有一个例外,就是当主键为整型值时,如果要插入一个非整型值时会产生异常。另外,虽然在插入或读出数据的时候是不区分类型的,但在比较的时候,不同数据类型是有区别的。比如:CREATE TABLE MyTable(a INTEGER,b TEXT);
INSERT INTO MyTable VALUES(0,0);
当执行下面的查询:
SELECT count(*)FROM MyTable WHERE a=='00';
会返回一条记录,因为字段a的类型是整型,而数字00与0是相等的。而执行下面的查询则不会返回记录:
SELECT count(*)FROM MyTable WHERE b=='00';
因为字段b是字符类型,字符"00"与"0"是不相等的。
SQLite提供了对Transaction的支持。应用Transaction即保证了数据的完整性,也会提高运行速度,因为多条语句一起提交给数据库的速度会比一条一条的提交方式更快。
SQLite库包括一个简单的命令行工具,该工具名称对应SQLite-3_2_2版本叫做sqlite3,用户使用这个工具可以对一个SQLite数据库手工输入和执行SQL命令。例如建立一个名叫wgy 的SQLite数据库,并建立一个名叫user的表的步骤如下:
Sqlite3wgy
SQLite version 3.2.1
Enter".help"for instructions
varchar(10));;
sqlite>create table user(username varchar(10),password varchar(10))
111111’’);
sqlite>insert into user values('Marry',
values('Marry',’’111111
values('Helen',’’222222
222222’’);
sqlite>insert into tbl1values('Helen',
sqlite>select*from user;
Marry|111111
Helen|222222
Sqlite>