java生成db文件
工作中遇到一个需求,就是需要把mysql里的一些表数据生成db文件,给客户端使用,客户端使用sqlite数据库;
首先我们需要在项目中添加Sqlite JDBC 依赖
<dependency>
<groupId>org.xerial</groupId>
<artifactId>sqlite-jdbc</artifactId>
<version>3.23.1</version>
</dependency>
生成DB文件工具类
package cn.kayun.util; import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.Statement;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Locale; /**
* Created by root on 2018/7/2 0002.
*/
public class DBUtil { private static final Logger logger = LoggerFactory.getLogger(DBUtil.class);
private static Connection connection = null;
private static Statement statement = null;
private static String username = "kanyun";
private static String password = "kanyun"; /**
* @describe: 设置连接 * @params: * @Author: Kanyun * @Date: 2018/7/12 9:54
*/
public static void setConnection() {
try {
// 声明驱动类型
Class.forName("org.sqlite.JDBC");
// 设置sqlite db文件存放基本目录
String path = DBUtil.class.getClassLoader().getResource("").getPath();
// 设置 sqlite文件路径,等同于mysql连接地址(jdbc:mysql://127.0.0.1:3306/test)
String url = "jdbc:sqlite:" + path + "data.db";
// 获取连接
connection = DriverManager.getConnection(url, username, password);
// 声明
statement = connection.createStatement();
} catch (Exception e) {
throw new RuntimeException("建立Sqlite连接失败");
} } /**
* @describe: 创建表
* @params: tableName: 要创建的表的名称 className:项目中Pojo的类名(需要注意的是该类名需要加上包名 如 com.xxx.xxx.pojo.xxx)
* @Author: Kanyun
* @Date: 2018/7/12 9:56
*/
public synchronized static void create(String tableName, String className) {
try {
statement.executeUpdate("DROP TABLE IF EXISTS " + tableName + ";");
// 通过反射,获取传入类名的字段信息
Field[] fields = Class.forName(className).getDeclaredFields();
StringBuffer sb = new StringBuffer();
String reg = " ";
sb.append("create table " + tableName + " (");
for (Field field : fields) {
// 设置使用反射时,可以访问私有变量,当pojo的变量设置为private修饰时,isAccessible()得到的值是false,必须要改成true才可以访问
field.setAccessible(true);
// 通过获得的字段,获取字段类型,和字段名,来定义创建表的字段名和字段类型
if (field.getType().getName().equals(java.lang.Long.class.getName())) {
sb.append(reg + field.getName() + " bigint(20) ");
} else if (field.getType().getName().equals(java.lang.String.class.getName())) {
sb.append(reg + field.getName() + " varchar(255) ");
} else if (field.getType().getName().equals(java.util.Date.class.getName())) {
sb.append(reg + field.getName() + " datetime ");
} else {
sb.append(reg + field.getName() + " int(11) ");
}
reg = ",";
}
sb.append(") ;");
statement.executeUpdate(sb.toString());
} catch (Exception e) {
logger.error("建表失败:" + e);
throw new RuntimeException("建表失败,表名称:" + tableName);
}
} /**
* @describe: 表中插入数据
* @params: tableName:表名 list:待插入的对象集合 需要注意的是插入的对象要跟表名对应
* @Author: Kanyun
* @Date: 2018/7/12 10:03
*/
public synchronized static <T> int insert(String tableName, List<T> list) {
StringBuffer declaration = new StringBuffer();
List<String> dataSqlArray = new ArrayList<>();
int count = 0;
try {
list.stream().map(t -> {
if (dataSqlArray.size() < 1) {
logger.info("定义语句");
Field[] fields = t.getClass().getDeclaredFields();
declaration.append(" (");
String reg = "";
for (Field field : fields) {
field.setAccessible(true);
declaration.append(reg + field.getName());
reg = ",";
}
declaration.append(")");
}
return t;
}).forEach((t) -> {
Field[] fields = t.getClass().getDeclaredFields();
StringBuffer oneData = new StringBuffer();
String reg = "";
oneData.append(" ("); for (Field field : fields) {
try {
field.setAccessible(true);
if (null == field.get(t) || "".equals(field.get(t))) {
oneData.append(reg + null);
} else if (field.getType().getName().equals(java.lang.String.class.getName())) {
// 传入的对象中字段是字符串时,插入数据库需要转义单引号
oneData.append(reg + "\'" + field.get(t) + "\'");
// 传入的对象中字段是日期类型时,先将日期转换为 yyyy-MM-dd 的形式(我这里,传入对象的日期对象格式为:Wed Jul 11 14:34:07 CST 2018),在将其转换成字符串,注意转义单引号
} else if (field.getType().getName().equals(java.util.Date.class.getName())) {
String dd = field.get(t).toString();
SimpleDateFormat sdf1 = new SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy", Locale.ENGLISH);
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String date = sdf2.format(sdf1.parse(dd));
oneData.append(reg + "\'" + date + "\'");
} else {
oneData.append(reg + field.get(t));
}
reg = ",";
} catch (Exception e) {
e.printStackTrace();
}
}
oneData.append(")");
dataSqlArray.add(oneData.toString());
});
String dataSql = StringUtils.join(dataSqlArray, ",");
String retSQL = "INSERT INTO " + tableName + declaration.toString()
+ " VALUES " + dataSql + ";";
System.out.println(retSQL);
PreparedStatement prep = connection.prepareStatement(retSQL);
// 设置自动提交
connection.setAutoCommit(true);
count = prep.executeUpdate();
} catch (Exception e) {
logger.error("插入失败:" + e);
e.printStackTrace();
}
return count;
} /**
* @describe: 关闭链接
* @params:
* @Author: Kanyun
* @Date: 2018/7/12 10:11
*/
public static void endConnection() {
try { connection.close(); } catch (Exception e) {
e.printStackTrace();
}
} }
生成的DB文件在classess目录下.
需要注意的是,在创建链接的过程中,虽然可以传入用户名,密码,但是使用一些工具(比如Navicat)还是可以查看db文件的内容的,因为免费版的SQLite有一个致命缺点:不支持加密
如果需要使用sqlite加密,一是数据本身进行加密,也就是往表中插入的数据进行加密,二是可以加密db文件本身
更多加密方式,参考:https://www.cnblogs.com/ligun123/p/5206942.html
java生成db文件的更多相关文章
- Java生成CSV文件实例详解
本文实例主要讲述了Java生成CSV文件的方法,具体实现步骤如下: 1.新建CSVUtils.java文件: package com.saicfc.pmpf.internal.manage.utils ...
- POI以SAX方式解析Excel2007大文件(包含空单元格的处理) Java生成CSV文件实例详解
http://blog.csdn.net/l081307114/article/details/46009015 http://www.cnblogs.com/dreammyle/p/5458280. ...
- Java生成XML文件
我们在数据库中的数据可以将其提取出来生成XML文件,方便传输.例如数据库中有Admin这张表: 我们写一个java类表示admin数据: package xmlDom.vo; import java. ...
- java生成压缩文件
在工作过程中,需要将一个文件夹生成压缩文件,然后提供给用户下载.所以自己写了一个压缩文件的工具类.该工具类支持单个文件和文件夹压缩.放代码: import java.io.BufferedOutput ...
- JAVA生成PDF文件
生成PDF文件是主要应用的是ITEXT插件 import java.awt.Color; import java.io.File; import java.io.FileOutputStream; i ...
- Java生成CSV文件
1.新CSVUtils.java文件: package com.saicfc.pmpf.internal.manage.utils; import java.io.BufferedWriter; im ...
- Java生成PDF文件(转)
原文地址:https://www.cnblogs.com/shuilangyizu/p/5760928.html 一.前言 前几天,做ASN条码收货模块,需要实现打印下载收货报表,经一番查找,选定iT ...
- [itext]Java生成PDF文件
一.前言 最近在做也导出试卷的功能,刚开始是导出为doc,可是导出来格式都有变化,最后说直接将word转为pdf,可是各种不稳定,各种报错.最后想到直接将文件写入pdf(参考:http://www.c ...
- Java生成压缩文件(zip、rar 格式)
jar坐标: <dependency> <groupId>org.apache.ant</groupId> <artifactId>ant</ar ...
随机推荐
- IntelliJ IDEA 在运行web项目时部署的位置
在idea中运行tomcat,把项目部署到其中,运行起来,去tomcat目录下去看,根本找不到部署的项目,那么项目是怎么运行的? 在idea中配置的tomcat,在运行时idea不会把项目放到该路径下 ...
- 递增三元组|2018年蓝桥杯B组题解析第六题-fishers
标题:递增三元组 给定三个整数数组 A = [A1, A2, ... AN], B = [B1, B2, ... BN], C = [C1, C2, ... CN], 请你统计有多少个三元组(i, j ...
- 第四次程序设计作业 C++计算器计算及命令行的使用 前缀表达式方法实现
关键词:前缀中缀后缀表达式 波兰式 命令行 myGithub 一.前言 很有意思的开发和学习经历,从刚刚开始看到作业思考半天到现在的Debug过程,对我来说都或多或少有所提升. 也许这个时候自己挺迷茫 ...
- python ros 回充demo
#!/usr/bin/env python #coding=utf- import rospy from std_msgs.msg import String i= def talker(): glo ...
- MongoDB(课时27 消除重复数据)
3.7.2 消除重复数据 在SQL中对于重复的数据可以使用"DISTINCT"消除,在MongoDB中依然支持.(distinct不同的) 范例:查询所有name的信息 本次的操作 ...
- set/multiset_01
按序排列 不能指定插入位置 红黑树变体 不可以直接存取元素(即 无[?]/at(?)操作) 不可以直接修改元素值(用 先删除后添加的方式,达到相同效果) A.头尾 添加/移除 B.随机存取 C.数据存 ...
- [调试][程序打印]当printf不能用时,使用C++的不定参数来搞定OutputDebugString打印
void _trace( char* str , ...) //类似printf{ va_list vlist; va_start(vlist , str ); char a [100] ; vspr ...
- java中的值传递和引用传递用法详解
值传递:方法调用时,实际参数把它的值传递给对应的形式参数,方法执行中形式参数值的改变不影响实际参 数的值. 引用传递:也称为传地址.方法调用时,实际参数的引用(地址,而不是参数的值)被传递给方法中相对 ...
- iconfont使用方法
最近才发现一种新的iconfont的使用方法 http://www.iconfont.cn/ 经常使用的图标放在一个项目里 需要关注的几点: 使用方法有三种方式unicode , font clas ...
- 雷林鹏分享:C# 文件的输入与输出
C# 文件的输入与输出 一个 文件 是一个存储在磁盘中带有指定名称和目录路径的数据集合.当打开文件进行读写时,它变成一个 流. 从根本上说,流是通过通信路径传递的字节序列.有两个主要的流:输入流 和 ...