SQLite总结
废话不多说:
优点,高并发读快速度读取超越所有主流大中型数据库
缺点,缺少同步机制,读写不能同时,且同时只能有一个写入线程
用途,硬盘式缓存
另附一SQLite工具类:
import java.io.FileWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.util.List;
import java.util.Map; public class SQLiteHelper { private static final String dbDriver = "org.sqlite.JDBC"; public static int createTable(String dbUrl, String sql) {
try {
if (sql == null || sql.trim().length() < 1)
return -1;
Class.forName(dbDriver); if (dbUrl.indexOf("jdbc:sqlite:") != 0) {
dbUrl = "jdbc:sqlite:" + dbUrl;
}
if (!dbUrl.endsWith(".db")) {
dbUrl = dbUrl + ".db";
} Connection con = DriverManager.getConnection(dbUrl);
con.setAutoCommit(true);
System.out.println(sql);
FileWriter wr = new FileWriter("create.sql", true);
wr.append(sql + "\n");
wr.close();
con.close();
return con.prepareStatement(sql).executeUpdate();
} catch (Exception e) {
e.printStackTrace();
}
return -1;
} public static int excuteUpdate(String dbUrl, String sql, Object[]... params) {
try {
if (sql == null || sql.trim().length() < 1)
return -1;
Class.forName(dbDriver); if (dbUrl.indexOf("jdbc:sqlite:") != 0) {
dbUrl = "jdbc:sqlite:" + dbUrl;
}
if (!dbUrl.endsWith(".db")) {
dbUrl = dbUrl + ".db";
} Connection con = DriverManager.getConnection(dbUrl);
con.setAutoCommit(false); Object[] param = null;
PreparedStatement ps = con.prepareStatement(sql);
for (int i = 0; i < params.length;) {
if (params != null) {
param = params[i];
for (int j = 1; j <= param.length;) {
if (param[j - 1] == null) {
continue;
}
ps.setObject(j, param);
j++;
}
}
ps.addBatch();
i++;
} int num = ps.executeUpdate();
ps.clearBatch();
con.commit();
con.close();
return num;
} catch (Exception e) {
e.printStackTrace();
}
return -1;
} public static List<Map<String, Object>> readDb(String dbUrl, String sql, Object... param) {
try {
if (sql == null || sql.trim().length() < 1)
return null;
if (dbUrl.indexOf("jdbc:sqlite:") != 0) {
dbUrl = "jdbc:sqlite:" + dbUrl;
}
if (!dbUrl.endsWith(".db")) {
dbUrl = dbUrl + ".db";
}
Class.forName(dbDriver);
Connection con = DriverManager.getConnection(dbUrl);
PreparedStatement ps = con.prepareStatement(sql);
for (int j = 1; j <= param.length;) {
if (param[j - 1] == null) {
continue;
}
ps.setObject(j, param);
j++;
}
con.close();
return new ListResult(ps.executeQuery()).getListRestlt();
} catch (Exception e) {
e.printStackTrace();
}
return null;
} }
SQLite总结的更多相关文章
- 【开源】分享2011-2015年全国城市历史天气数据库【Sqlite+C#访问程序】
由于个人研究需要,需要采集天气历史数据,前一篇文章:C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子),介绍了基本的采集思路和核心代码,经过1个星期的采集,历史数据库 ...
- UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?
选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...
- 深入解析Sqlite的完美替代者,android数据库新王者——Realm
写在前面: 又到一年一度七夕虐狗节,看着大家忍受着各种朋友圈和QQ空间还有现实生活中的轮番轰炸,我实在不忍心再在这里给大家补刀,所以我觉得今天不虐狗,继续给大家分享有用的. 如果你比较关心androi ...
- VS15 preview 5打开文件夹自动生成slnx.VC.db SQLite库疑惑?求解答
用VS15 preview 5打开文件夹(详情查看博客http://www.cnblogs.com/zsy/p/5962242.html中配置),文件夹下多一个slnx.VC.db文件,如下图: 本文 ...
- Android之SQLite数据存储
一.SQLite保存数据介绍 将数据库保存在数据库对于重复或者结构化数据(比如契约信息)而言是理想之选.SQL数据库的主要原则之一是架构:数据库如何组织正式声明.架构体现于用于创建数据库的SQL语句. ...
- 【教程】SQLite数据库修复
SQLite 大家都知道,就不多说了. 有时候数据量大了,或者存储过程中出现异常,数据库就可能会出问题. 这是以前公司产品出现过的问题,导致软件都打不开了,我花了不少时间才解决的,趁现在有空贡献出来. ...
- SQLite学习笔记(十)&&加密
随着移动互联网的发展,手机使用越来越广泛,sqlite作为手机端存储的一种解决方案,使用也非常普遍.但是sqlite本身安全特性却比较弱,比如不支持用户权限,只要能获取到数据库文件就能进行访问:另外也 ...
- mono for android中使用dapper或petapoco对sqlite进行数据操作
在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.( ...
- 【腾讯Bugly干货分享】微信iOS SQLite源码优化实践
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57b58022433221be01499480 作者:张三华 前言 随着微信iO ...
- 【腾讯Bugly干货分享】移动客户端中高效使用SQLite
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57b57f2a0703f7d31b9a3932 作者:赵丰 导语 iOS 程序能 ...
随机推荐
- Rtsp转Flv在浏览器中播放
目录 概述 环境 项目目录清单 项目搭建步骤 引入相关npm依赖 实例化一个express应用 创建WebsocketServer并解析rtsp 使用flv播放 浏览器中测试 代码 引用 概述 众所周 ...
- axios post xml data方法
axios#request(config) axios#get(url[,config]) axios#delete(url[,config]) axios#head(url[,config]) ax ...
- nrm 安装报错 解决方案
想用 npm login 发现用的淘宝镜像,一看安装个nrm,结果运行还报错了.你看看. 改下,登录完再改回来. https://blog.csdn.net/mynewdays/article/det ...
- 吐槽 Android的WebView的pauseTimers方法神坑 webview加载卡住
原文: 吐槽 Android的WebView的pauseTimers方法神坑 webview加载卡住 | Stars-One的杂货小窝 说明 之前公司的项目和别的公司一起合作,忽然出现情况,进入到他们 ...
- [置顶]
java动态控制线程的启动和停止
最近项目有这样的需求:原来系统有个计算的功能,但该功能执行时间会很长(大概需要几个小时才能完成),如果执行过程中出现了错误的话,也只能默默的等待错误执行完成才行,无法做到动态的对该功能进行停止. 我了 ...
- clickhouse 安装和远程登录开启
一.Clickhouse的安装 1.添加yum源 yum-config-manager --add-repo http://repo.red-soft.biz/repos/clickhouse/rep ...
- nginx location块
location块在server块中使用,它的作用是根据客户端请求URL去定位不同的应用. 匹配格式 作用 location = /uri = 表示精确匹配,只有完全匹配上才能生效 location ...
- 数字集成电路设计之CMOS
数字集成电路设计理论 1.基本的理论结构 现在主流的集成电路器件还是CMOS,所以理论的结构还是基于CMOS.CMOS有N和P两种MOS组合组合在一起.CMOS最简单的器件就是反相器.然后是标准的逻辑 ...
- KingbaseES例程_普通表在线转分区表(基于规则)
KingbaseES例程_普通表在线转分区表 概述 普通表转分区表,使用视图的替换式规则,以路由方式,实现在线转移数据. 数据准备 /*普通大表*/ create table tab_single a ...
- 一文搞懂Javaweb的响应状态码
一.状态码大类 状态码分类 说明 1xx 响应中--临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它 2xx 成功--表示请求已经被成功接收,处理已完成 3xx 重定向- ...