加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite 在 Java中的使用

发布时间:2020-12-12 20:07:24 所属栏目:百科 来源:网络整理
导读:本文是根据 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驱动。内部使
本文是根据 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安装目录下的jrelibext路径下;把sqlite_jni.dll拷到对应的
jrebin目录下。
然后创建一个Eclipse工程sqlite,把这两个文件添加到你的工程里就可以了。
其实不把上述的两个文件添加到sdk下面的路径也是可以的,只要保证你的工程里可以顺利的调用到这两个文件就可以了。

3、 开始写测试类
创建一个HelloSqlite.java 。
引入相关类:import SQLite.*,这样就可以使用sqlite.jar里面的类了,
初始化一个Database对象:Database db = new Database();
我在HelloSqlite.java里面就简单得调用了Database.Version()来查看当前数据库的版本。
代码如下:
Java代码
  1. importSQLite.*;
  2. publicclassHelloSqlite{
  3. Databasedb=newDatabase();
  4. publicstaticvoidmain(String[]args){
  5. HelloSqlites=newHelloSqlite();
  6. System.out.println(s.db.version());
  7. }
  8. }


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

5.建表语句
Java代码
  1. staticfinalStringstrCreate="createtableuser(useridintegerprimarykey,usernametext)";

增加执行方法:
Java代码
  1. publicintexcute(Stringsql){
  2. try{
  3. db.exec(sql,newTableFmt());//这是回调函数,用于处理返回结果。后面有介绍
  4. return1;
  5. }catch(java.lang.Exceptione){
  6. e.printStackTrace();
  7. return-1;
  8. }
  9. }


6.写入,查询语句
Java代码
  1. staticfinalStringstrInsert="insertintouservalues(2,'James')";
  2. staticfinalStringstrDisplay="select*fromuser";

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


8.执行测试
Java代码
  1. publicstaticvoidmain(String[]args){
  2. HelloSqlites=newHelloSqlite();
  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. }


执行结果:
Java代码
  1. 2.8.17
  2. columns
  3. userid
  4. username
  5. newrow
  6. 2
  7. James


9.完整代码
Java代码
  1. importSQLite.*;
  2. publicclassHelloSqlite{
  3. Databasedb=newDatabase();
  4. staticfinalStringstrCreate="createtableuser(useridintegerprimarykey,usernametext)";
  5. staticfinalStringstrInsert="insertintouservalues(2,'James')";
  6. staticfinalStringstrDisplay="select*fromuser";
  7. publicintconnectDB(StringdbPath){
  8. try{
  9. db.open(dbPath,0666);
  10. return1;
  11. }catch(java.lang.Exceptione){
  12. e.printStackTrace();
  13. return-1;
  14. }
  15. }
  16. publicintexcute(Stringsql){
  17. try{
  18. db.exec(sql,newTableFmt());
  19. return1;
  20. }catch(java.lang.Exceptione){
  21. e.printStackTrace();
  22. return-1;
  23. }
  24. }
  25. publicstaticvoidmain(String[]args){
  26. HelloSqlites=newHelloSqlite();
  27. System.out.println(s.db.version());
  28. s.connectDB("abc.db");
  29. s.excute(strCreate);
  30. s.excute(strInsert);
  31. s.excute(strDisplay);
  32. }
  33. }
  34. classTableFmtimplementsCallback{
  35. publicvoidcolumns(String[]cols){
  36. System.out.println("columns");
  37. for(inti=0;i<cols.length;i++){
  38. System.out.println(cols[i]);
  39. }
  40. }
  41. publicbooleannewrow(String[]cols){
  42. System.out.println("newrow");
  43. for(inti=0;i<cols.length;i++){
  44. System.out.println(cols[i]);
  45. }
  46. returnfalse;
  47. }
  48. publicvoidtypes(String[]cols){
  49. System.out.println("types");
  50. for(inti=0;i<cols.length;i++){
  51. System.out.println(cols[i]);
  52. }
  53. }
  54. }



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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读