设为首页 收藏本站
查看: 802|回复: 0

[经验分享] SQLite 在 Java中的使用

[复制链接]

尚未签到

发表于 2016-11-29 08:58:53 | 显示全部楼层 |阅读模式
本文是根据
http://www.sqlite.com.cn/MySqlite/3/31.Html
http://www.sqlite.com.cn/MySqlite/3/80.Html
结合自己的理解所得。
Javasqlite提供了sqlite的java包装,使用这个库可以方便的在java中使用sqlite。它包含了一个可以调用sqlite的JDBC驱动。内部使用了JNI来调用Sqlite的Interface。以下简单介绍一下如何在Eclipse中配置一个可以调用sqlite的工程:

1、  下载javasqlite包:
官方网站上还提供简单的文档。http://www.ch-werner.de/javasqlite
其中有jar包和源码下载的链接。
http://www.ch-werner.de/javasqlite/javasqlite-20100131.tar.gz
http://www.ch-werner.de/javasqlite/javasqlite-20100131-win32.zip
2、  配置Eclipse工程:
把sqlite.jar拷到你的sdk安装目录下的\jre\lib\ext\路径下;把sqlite_jni.dll拷到对应的
\ jre\bin\目录下。
然后创建一个Eclipse工程sqlite,把这两个文件添加到你的工程里就可以了。
其实不把上述的两个文件添加到sdk下面的路径也是可以的,只要保证你的工程里可以顺利的调用到这两个文件就可以了。
3、  开始写测试类
创建一个HelloSqlite.java 。
引入相关类:import SQLite.* ,这样就可以使用sqlite.jar里面的类了,
初始化一个Database对象:Database db = new Database();
我在HelloSqlite.java里面就简单得调用了Database.Version()来查看当前数据库的版本。
代码如下:

import SQLite.*;
public class HelloSqlite {
Database db=new Database();
public static void main(String[] args) {
HelloSqlite s=new HelloSqlite();
System.out.println(s.db.version());
}
}


4.连接数据库:

public int connectDB(String dbPath)
{
try{
db.open(dbPath,0666);//调用open方法连接数据库,如果不存在创建这个数据库文件,该数据库将产生在项目工程的根目录下。
return 1;
}
catch(java.lang.Exception ex)
{
ex.printStackTrace();
return -1;
}
}

5.建表语句

static final String strCreate ="create table user (userid integer primary key, username text)";

增加执行方法:

public int excute(String sql){
try {
db.exec(sql, new TableFmt());//这是回调函数,用于处理返回结果。后面有介绍
return 1;
} catch (java.lang.Exception e) {
e.printStackTrace();
return -1;
}
}


6.写入,查询语句

static final String strInsert ="insert into user values (2,'James')";
static final String strDisplay ="select * from user";

7.处理查询结果
实现了SQLite. Callback接口,接着将这个类的一个对象传递给exec的Callback参数。这样exec就会对每个查询结果调用Callback。继而实现对结果的处理

class TableFmt implements Callback{
public void columns (String[] cols){
System.out.println("columns");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
}
public boolean newrow(String[] cols){
System.out.println("newrow");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
return false;
}
public void types(String[] cols){
System.out.println("types");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
}
}


8.执行测试

public static void main(String[] args) {
HelloSqlite s=new HelloSqlite();
System.out.println(s.db.version());
s.connectDB("abc.db");
s.excute(strCreate);
s.excute(strInsert);
s.excute(strDisplay);
}


执行结果:

2.8.17
columns
userid
username
newrow
2
James


9.完整代码

import SQLite.*;
public class HelloSqlite {
Database db=new Database();
static final String strCreate ="create table user (userid integer primary key, username text)";
static final String strInsert ="insert into user values (2,'James')";
static final String strDisplay ="select * from user";
public int connectDB(String dbPath){
try {
db.open(dbPath, 0666);
return 1;
} catch (java.lang.Exception e) {
e.printStackTrace();
return -1;
}
}

public int excute(String sql){
try {
db.exec(sql, new TableFmt());
return 1;
} catch (java.lang.Exception e) {
e.printStackTrace();
return -1;
}
}
public static void main(String[] args) {
HelloSqlite s=new HelloSqlite();
System.out.println(s.db.version());
s.connectDB("abc.db");
s.excute(strCreate);
s.excute(strInsert);
s.excute(strDisplay);
}
}
class TableFmt implements Callback{
public void columns (String[] cols){
System.out.println("columns");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
}
public boolean newrow(String[] cols){
System.out.println("newrow");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
return false;
}
public void types(String[] cols){
System.out.println("types");
for (int i = 0; i < cols.length; i++) {
System.out.println(cols);
}
}
}


另外,Sqlite JDBC 是一个sqlite的jdbc操作包,使用它后,我们就可以像操作其他数据库一样操作sqlite。详情请见http://www.zentus.com/sqlitejdbc/

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-306967-1-1.html 上篇帖子: Sqlite使用中的几点体会。 下篇帖子: sqlite可视化工具sqlite administrator 下载与使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表