SQLite 在 Java中的使用

前端之家收集整理的这篇文章主要介绍了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()来查看当前数据库的版本。
代码如下:
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. }
@H_502_364@ 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); }

执行结果:
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

猜你在找的Sqlite相关文章