背景:

  Java > maven 的 jar 项目

  功能是记录用户的每天的按键次数

  使用 jar2exe 工具将 jar 转为 exe 可执行文件

  原本项目中使用的Mysql数据库,使用Mybatis工具操作运行没有问题

  后来发现对于一个小工具来说,用Mysql太麻烦,因为需要安装配置Mysql等等.

  于是我上网查了查,找到了一个轻量级的嵌入式数据库SQLite

  导入一个 org.xerial > sqlite-jdbc jar 包,直接就可以创建数据库文件了十分方便

  当时用的 jar 是最新的版本 3.20.0

  费了一天的劲,将之前的持久层代码从Mysql替换成了SQLite

问题介绍:

  在编辑器内运行良好

  编译成 jar 后,使用 java -jar ***.jar 运行良好

  当我把 jar 用 jar2exe 转成 exe 运行文件后, 它就报错了

  错误信息如下:

  1. java.sql.SQLException: Error opening connection
  2. at org.sqlite.core.CoreConnection.open(CoreConnection.java:215)
  3. at org.sqlite.core.CoreConnection.<init>(CoreConnection.java:76)
  4. at org.sqlite.jdbc3.JDBC3Connection.<init>(JDBC3Connection.java:26)
  5. at org.sqlite.jdbc4.JDBC4Connection.<init>(JDBC4Connection.java:24)
  6. at org.sqlite.SQLiteConnection.<init>(SQLiteConnection.java:45)
  7. at org.sqlite.JDBC.createConnection(JDBC.java:114)
  8. at org.sqlite.JDBC.connect(JDBC.java:88)
  9. at com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManagerDataSource.java:119)
  10. at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:143)
  11. at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:132)
  12. at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPoolManager.initializeAutomaticTestTable(C3P0PooledConnectionPoolManager.java:772)
  13. at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPoolManager.createPooledConnectionPool(C3P0PooledConnectionPoolManager.java:696)
  14. at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPoolManager.getPool(C3P0PooledConnectionPoolManager.java:257)
  15. at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPoolManager.getPool(C3P0PooledConnectionPoolManager.java:271)
  16. at com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:128)
  17. at com.play.util.SQLiteUtil.openConnection(SQLiteUtil.java:56)
  18. at com.play.base.BaseDaoImpl.execute(BaseDaoImpl.java:54)
  19. at com.play.dao.impl.KeyRecordDayDaoImpl.add(KeyRecordDayDaoImpl.java:22)
  20. at com.play.DataManager.addToDayRecord(DataManager.java:75)
  21. at com.play.DataManager.addBeat(DataManager.java:58)
  22. at com.play.DataManager.lambda$new$0(DataManager.java:32)
  23. at java.lang.Thread.run(Thread.java:748)
  24. Caused by: java.lang.NullPointerException
  25. at org.sqlite.SQLiteJDBCLoader.loadSQLiteNativeLibrary(SQLiteJDBCLoader.java:315)
  26. at org.sqlite.SQLiteJDBCLoader.initialize(SQLiteJDBCLoader.java:64)
  27. at org.sqlite.core.NativeDB.load(NativeDB.java:56)
  28. at org.sqlite.core.CoreConnection.open(CoreConnection.java:211)
  29. ... 21 more

  很伤脑筋,上网查了半天没有查到相关问题

  最终翻墙到谷歌上搜索了一番

  找到了一个类似的问题,全是英文,具体没看太懂

  但是里面提到了 sqlite-jdbc jar 版本的问题.

  于是我抱着试试看的心态

  将版本改成了 3.8.11.2

  编译完成 > 转 exe 完成 > 运行成功> 问题解决!

Java项目使用SQLite数据库后无法启动的问题的更多相关文章

  1. Springboot项目 配置数据库连接属性后,启动项目报错

    Springboot项目 配置数据库连接属性后,启动项目报错,错误如下: 错误原因分析: 1.连接信息配置错误 当使用properties为配置文件时,如图所示,上面的 spring.datasour ...

  2. Java项目专栏之数据库建表

    Java项目专栏之数据库建表 数据库建表前期准备 1. 安装mysql:数据库语言,语法和sql server差不太多,如果习惯于sql server可以不用mysql. 2. 安装navicat:可 ...

  3. SpringBoot项目打包成jar后,启动脚本

    将springboot项目打包成jar后,上传至服务器,每次都需要手敲命令,重新部署项目,可将这些命令写入脚本中,直接运行. 启动脚本(start.sh): CUR_PATH=$(cd "$ ...

  4. java项目部署Linux服务器几种启动方式总结经验

    一:两种部署包: 部署之前先说下两种包,java项目部署到服务器一般有用war包的,也有用jar包的,微服务spring-cloud普及后大部分打包都是jar,部署之前先搞清楚自己要打war包还是ja ...

  5. Java 项目JDBC 链接数据库中会出现的错误

    1.出现的地方 package com.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql ...

  6. 安卓项目-利用Sqlite数据库,开发新闻发布系统

    本教程致力于程序员可以快速的学习安卓移动端手机开发. 适合于已经习得一种编程语言的同仁. 更多志同道合,想要学习更多编程技术的大神们. 小弟不才,麻烦关注一下我的今日头条号-做全栈攻城狮. 本文章是基 ...

  7. 在Java中使用Sqlite数据库

    一.安装 下载最新的 Sqlite Jdbc 驱动程序jar文件,并添加到Java工程的class路径下: 二.使用 以 sqlite Jdbc 驱动版本为 sqlitejdbc-v56.jar 为例 ...

  8. JDBC(Java项目使用Oracle数据库)

    Java项目中使用Oracle数据库(Eclipse) 前言 这学期选了Oracle数据库这门课,于是自己下载了Oracle11gR2版本的数据库.在这之前我一直用的是MySQL.虽然两者教程差不多, ...

  9. java 项目连接MySQL数据库

    1.导入jar包 mysql-connector-java-5.1.35百度云链接如下: 链接:https://pan.baidu.com/s/1DPvIwU_An4MA3mU5bQa6VA 密码:5 ...

随机推荐

  1. Windows 通过批处理自动执行 linux服务器上面命令的办法

    1. 使用putty 下载地址 https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html 直接使用 exe版本就可以 https:/ ...

  2. codeforces721C

    Journey CodeForces - 721C Recently Irina arrived to one of the most famous cities of Berland — the B ...

  3. Vuex、axios、跨域请求处理和import/export的注意问题

    一.Vuex 1.介绍 vuex是一个专门为Vue.js设计的集中式状态管理架构. 对于状态,我们把它理解为在data中需要共享给其他组件使用的部分数据. Vuex和单纯的全局对象有以下不同: 1. ...

  4. Day 4 测试(QwQ 表示没考好 未完待续。。。 可能要过一段时间才会更

    #include<iostream> #include<algorithm> #include<cstdio> #include<cstring> #i ...

  5. 清北澡堂 Day2 下午 一些比较重要的数论知识整理

    1.欧拉定理 设x1,x2,.....,xk,k=φ(n)为1~n中k个与n互质的数 结论一:axi与axj不同余 结论二:gcd(axi,n)=1 结论三:x1,x2,...,xk和ax1,ax2, ...

  6. Maze HDU - 4035(期望dp)

    When wake up, lxhgww find himself in a huge maze. The maze consisted by N rooms and tunnels connecti ...

  7. P1313 计算系数

    题目描述 给定一个多项式(by+ax)k(by+ax)^k(by+ax)k,请求出多项式展开后xn×ymx^n \times y^mxn×ym项的系数. 输入输出格式 输入格式: 共一行,包含555个 ...

  8. 联想的笔记本有隐藏分区 导致无法安装win10 eufi启动 报错:windows无法更新计算机的启动配置。无法安装

    联想的笔记本都带着类似一键还原等的系统恢复软件,这些软件往往是将出厂设置备份在单 独的一个分区,此分区默认为隐藏,在 Windows 的磁盘管理中可以看到.打开磁盘管理器 的方法是右击计算机——管理, ...

  9. vue实战记录(一)- vue实现购物车功能之前提准备

    vue实战,一步步实现vue购物车功能的过程记录,课程与素材来自慕课网,自己搭建了express本地服务器来请求数据 作者:狐狸家的鱼 本文链接:vue实战-实现购物车功能(一) GitHub:sue ...

  10. Vue的钩子函数[路由导航守卫、keep-alive、生命周期钩子]

    前言 说到Vue的钩子函数,可能很多人只停留在一些很简单常用的钩子(created,mounted),而且对于里面的区别,什么时候该用什么钩子,并没有仔细的去研究过,且Vue的生命周期在面试中也算是比 ...