您的位置:首页 > 博客中心 > 数据库 >

Java使用jdbc连接Sqlite数据库进行各种数据操作的详细过程

时间:2022-03-16 10:01

前言:
      SQLite是遵守ACID 的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。
       不像常见的客户-服务器范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分。所以主要的通信协议是在编程语言内的直接API调用。这在消耗总量、延迟时间和整体简单性上有积极的作用。整个数据库(定义、表、索引和数据本身)都在宿主主机上存储在一个单一的文件中。它的简单的设计是通过在开始一个事务的时候锁定整个数据文件而完成的。


一,准备sqlite数据源
由于sqlite是内存数据库,还会有一个数据文件,本质上是去访问一个文件,所以可以把linux下的sqlite的库文件copy出来到自己笔记本本地,然后在调用java程序访问操作sqlite库。

(1),安装sqlite
下载地址: Wget http://www.sqlite.org/2014/sqlite-autoconf-3080403.tar.gz
开始安装:
tar xvfz sqlite-autoconf-3080403.tar.gz
cd sqlite-autoconf-3080403
./configure --prefix=/usr/local
make
make install

(2),准备数据源
[root@localhost sqlite-autoconf-3080403]# sqlite3 tim.db
SQLite version 3.8.4.3 2014-04-03 16:53:12
Enter ".help" for usage hints.
sqlite> .table
sqlite> create table t1(id int);
sqlite> insert into t1 select 1;
sqlite> .exit
[root@localhost sqlite-autoconf-3080403]# ll tim.db
-rw-r--r-- 1 root root 2048 Aug 29 09:34 tim.db
[root@localhost sqlite-autoconf-3080403]# 

(3),通过SecureFX工具把tim.db数据文件copy到本地磁盘E盘根目录下面,如下图所示:

gxlsystem.com,布布扣


二,开始准备Eclipse环境
加载jdbc的jar包,jdbc的jar包 sqlitejdbc-v033-nested.jar,下载地址为:http://pan.baidu.com/s/1hqj7tT6

并且将其添加到classpath系统环境变量中:点击java工程右键,选择最后一个选项Properties,再选择Java Build Path,再选择Libraries,再选择Add External JARs...,然后加载本地的sqlitejdbc-v033-nested.jar包,加载路径过程如下图所示:
gxlsystem.com,布布扣


三,编写java代码连接sqlite数据库操作
(1),创建java代码测试类

  1. 四,调试运行:
    (1),第一次调试报错如下:
    Exception in thread "main" java.lang.ClassNotFoundException: org.sqlite.JDBC
    at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
    at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:169)

    解决方法:首先需要将sqlitejdbc-v056.jar包加入到工程中:
    右键你的工程->Build Path->configure Build Path->Libraries->Add External JARs->
    找到sqlitejdbc-v033-nested.jar包就可以了。

    (2),再运行报错如下:
    jdbc:sqlite://E:/u/sqllite/db/powerlong_208.db
    java.sql.SQLException: out of memory
    at org.sqlite.DB.throwex(DB.java:252)
    at org.sqlite.NestedDB.open(NestedDB.java:47)
    at org.sqlite.Conn.<init>(Conn.java:36)
    at org.sqlite.JDBC.connect(JDBC.java:38)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at foo.Main.main(Main.java:41)

    问题解决:是数据源的路径有问题,java不识别大写的E:盘,String sql="jdbc:sqlite://E:/tim.db";中的E:换成e:就可以调试通过了。


    五,运行结果,代码类里面右键选择Run As,再选择Java Application,执行结果如下所示:
    创建表结构录入数据操作演示:
    name = ZhangSan, salary = 8000
    name = LiSi, salary = 7800
    name = WangWu, salary = 5800
    name = ZhaoLiu, salary = 9100
    表结构变更操作演示:
    name = ZhangSan, name = ZhangSan, address = changsha
    name = LiSi, name = LiSi, address = changsha
    name = WangWu, name = WangWu, address = changsha
    name = ZhaoLiu, name = ZhaoLiu, address = changsha
    name = HongQi, name = HongQi, address = tianjing
    name = HongQi, name = HongQi, address = changsha

    操作界面如下所示:
    gxlsystem.com,布布扣


    六,后续继续研究:
    (1)windows下研究sqlite安装使用
    (2)java代码如何直接远程连接linux上面的sqlite库





热门排行

今日推荐

热门手游