设为首页 收藏本站
查看: 1195|回复: 0

[经验分享] 关于JDBC下使用SQLite DB问题总结(Windows下和Linux下使用)

[复制链接]

尚未签到

发表于 2016-3-30 09:56:19 | 显示全部楼层 |阅读模式
关于JDBC下使用SQLite DB问题总结

   因为公司的服务器在Linux下,同时也需要在Windows下运行,所以这方面的工作必须做的仔细。以下几点收获可以给大伙分享,避免因为一些低级错误影响项目开发。

   在Windows下SQLite JDBC 路径必须是小写,并且路径中需要添加/

   在Linux下SQLite JBDC路径严格区分大小写,并且路径中不需要添加/

   所以在使用过程一定要注意:以下几行代码就是判断这个环境的:

public synchronized List getPetternList(String pattern) throws Exception{
log.info("getPetternList DB="+pattern);
String path = MLotteryContext.getInstance().get("pettern.dir");
File pathDir = new File(path);
if(!pathDir.exists())
pathDir.mkdirs();
log.info("pathDir = "+pathDir);
String petternPath = path+"pattern.db";
File newFile = new File(petternPath);
log.info("==========start delete Old Pettern DB==========");
deleteFile(newFile);
log.info("==========End   delete Old Pettern DB==========");
log.info("======Start =======Write Pettern DB===============");
//------------------------
//if (!newFile.exists()) {
//newFile.createNewFile();
//}
//log.info("=============setExecutable===============");
//newFile.setExecutable(true);
//log.info("=============setReadable=================");
//newFile.setReadable(true);
//log.info("=============setWritable=================");
//newFile.setWritable(true);
//InputStream inStream = new FileInputStream(pattern);
//FileOutputStream fs = new FileOutputStream(newFile);
//byte[] buffer = new byte[1444];
//int bytesum = 0;
//int byteread = 0;
//while ((byteread = inStream.read(buffer)) != -1) {
//bytesum += byteread;
//log.info("=============bytesum===="+bytesum);
////System.out.println(bytesum);
//fs.write(buffer, 0, byteread);
//}
//inStream.close();
//log.info("======End  =======Write Pettern DB===============");
File oldFile = new File(pattern);
boolean bool = oldFile.renameTo(newFile);
log.info("Current PetternDB:"+newFile.getPath()+" bool = " + bool);
Class.forName("org.sqlite.JDBC");
log.info("DB="+petternPath);
log.info("====Start get Server System Type ==========");
Properties props=System.getProperties(); //获得系统属性集
String osName = props.getProperty("os.name"); //操作系统名称
log.info("Current OS Type :"+osName);
log.info("====End  get Server System Type ==========");
osName = osName.toLowerCase();
int index = 0;
index = osName.indexOf("windows");
String JDBC = "jdbc:sqlite:"+petternPath;
if(index > -1){
petternPath = petternPath.toLowerCase();
JDBC="jdbc:sqlite:/"+petternPath;
}
log.info("path = "+petternPath);
log.info("JDBC: "+JDBC);
Connection conn = DriverManager.getConnection(JDBC);
log.info("getPetternList conn="+conn.toString());
Statement stat = conn.createStatement();
ResultSet rs = stat.executeQuery("select * from pattern");
List<String> list = null;
if(rs != null){
list = new ArrayList<String>();
}
while (rs.next()) {
String pid = rs.getString("pattern_id");
log.info("pattern_id = "+pid);
list.add(pid);
}
rs.close();
conn.close();
deleteFile(newFile);
return list;
}只有这样做才能避免老是出现:

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(DriverManager.java:582)


这种无厘头的异常!!!!!


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-197606-1-1.html 上篇帖子: SQLite数据库在Linux中权限问题 下篇帖子: 谁给我发个SQLite3.dll 文件 。。。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表