电脑爱好者之家

当前位置: 主页 > JAVA编程文档 >

SQLite 在 Java中的使用(教程)

时间:2016-08-22 00:50来源:未知 作者:机器AI 点击:
SQLite 在 Java中的使用(教程) 本文是根据 http://www.sqlite.com.cn/MySqlite/3/31.Html http://www.sqlite.com.cn/MySqlite/3/80.Html 结合自己的理解所得。 Javasqlite提供了sqlite的java包装,使用这个库可以方便的在java中使用sqlite。它包含了一个可以
SQLite 在 Java中的使用(教程)
本文是根据 
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()来查看当前数据库的版本。 
代码如下: 
  1. import SQLite.*;
  2. public class HelloSqlite {
  3. Database db=new Database();
  4. public static void main(String[] args) {
  5.   HelloSqlite s=new HelloSqlite();
  6.   System.out.println(s.db.version());
  7. }
  8. }
复制代码


4.连接数据库: 
  1. public int connectDB(String dbPath)
  2. {
  3.     try{
  4.         db.open(dbPath,0666);//调用open方法连接数据库,如果不存在创建这个数据库文件,该数据库将产生在项目工程的根目录下。
  5.         return 1;
  6.     }
  7.    catch(java.lang.Exception ex)
  8.    {
  9.        ex.printStackTrace();
  10.        return -1;
  11.    }
  12. }
复制代码

5.建表语句 
  1. static final String strCreate ="create table user (userid integer primary key, username text)";
复制代码



增加执行方法:
  1. public int excute(String sql){
  2.   try {
  3.    db.exec(sql, new TableFmt());//这是回调函数,用于处理返回结果。后面有介绍
  4.    return 1;
  5.   } catch (java.lang.Exception e) {
  6.    e.printStackTrace();
  7.    return -1;
  8.   }
  9. }
复制代码


6.写入,查询语句static final String strInsert ="insert into user values (2,'James')";
  1. static final String strDisplay ="select * from user";
复制代码

7.处理查询结果 
实现了SQLite. Callback接口,接着将这个类的一个对象传递给exec的Callback参数。这样exec就会对每个查询结果调用Callback。继而实现对结果的处理 
  1. class TableFmt implements Callback{
  2. public void columns (String[] cols){
  3.   System.out.println("columns");
  4.   for (int i = 0; i < cols.length; i++) {
  5.    System.out.println(cols);
  6.   }
  7. }
  8. public boolean newrow(String[] cols){
  9.   System.out.println("newrow");
  10.   for (int i = 0; i < cols.length; i++) {
  11.    System.out.println(cols);
  12.   }
  13.   return false;
  14. }
  15.  
  16. public void types(String[] cols){
  17.   System.out.println("types");
  18.   for (int i = 0; i < cols.length; i++) {
  19.    System.out.println(cols);
  20.   }
  21. }
  22. }
  23.  
复制代码




8.执行测试
  1. public static void main(String[] args) {
  2.   HelloSqlite s=new HelloSqlite();
  3.   System.out.println(s.db.version());
  4.   s.connectDB("abc.db");
  5.   s.excute(strCreate);
  6.   s.excute(strInsert);
  7.   s.excute(strDisplay);
  8. }
复制代码

执行结果: 
2.8.17
columns
userid
username
newrow
2
James

9.完整代码 
  1. import SQLite.*;
  2. public class HelloSqlite {
  3. Database db=new Database();
  4. static final String strCreate ="create table user (userid integer primary key, username text)";
  5. static final String strInsert ="insert into user values (2,'James')";
  6. static final String strDisplay ="select * from user";
  7. public int connectDB(String dbPath){
  8.   try {
  9.    db.open(dbPath, 0666);
  10.    return 1;
  11.   } catch (java.lang.Exception e) {
  12.    e.printStackTrace();
  13.    return -1;
  14.   }
  15. }
  16.  
  17.  
  18. public int excute(String sql){
  19.   try {
  20.    db.exec(sql, new TableFmt());
  21.    return 1;
  22.   } catch (java.lang.Exception e) {
  23.    e.printStackTrace();
  24.    return -1;
  25.   }
  26.  
  27. public static void main(String[] args) {
  28.   HelloSqlite s=new HelloSqlite();
  29.   System.out.println(s.db.version());
  30.   s.connectDB("abc.db");
  31.   s.excute(strCreate);
  32.   s.excute(strInsert);
  33.   s.excute(strDisplay);
  34. }
  35. }
  36. class TableFmt implements Callback{
  37. public void columns (String[] cols){
  38.   System.out.println("columns");
  39.   for (int i = 0; i < cols.length; i++) {
  40.    System.out.println(cols);
  41.   }
  42. }
  43. public boolean newrow(String[] cols){
  44.   System.out.println("newrow");
  45.   for (int i = 0; i < cols.length; i++) {
  46.    System.out.println(cols);
  47.   }
  48.   return false;
  49. }
  50.  
  51. public void types(String[] cols){
  52.   System.out.println("types");
  53.   for (int i = 0; i < cols.length; i++) {
  54.    System.out.println(cols);
  55.   }
  56. }
  57. }
复制代码


另外,Sqlite JDBC 是一个sqlite的jdbc操作包,使用它后,我们就可以像操作其他数据库一样操作sqlite。 (责任编辑:机器AI)
织梦二维码生成器
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片