Java读写db文件及图片在db文件中的读写

47 篇文章 0 订阅
4 篇文章 1 订阅
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class SqliteDemo {

	// 本地图片路径
	private static final String srcPath = "D:/myImagines";

	// db文件生成路径
	private static final String desPath = "D:/";

	public static void main(String[] args) {
		try {
			String rootRirPath = srcPath;
			Class.forName("org.sqlite.JDBC");
			/**1.创建/连接数据库文件,创建操作也可以通过sqlitespy这个工具完成,强烈安利此利器,可搜我的另一博客:正确打开db文件的方式,避免乱码和无意义内容*/
			Connection connection = DriverManager.getConnection("jdbc:sqlite:"+desPath+"myTest.db");
			connection.setAutoCommit(false);
			Statement statement = connection.createStatement();
			// 2.创建表格或视图
			ResultSet resultSet = null;
			//-- 表:images
			resultSet = statement.executeQuery("select * from sqlite_master where type = 'table' and name = 'images'");
			if(!resultSet.next()){
				statement.executeUpdate("CREATE TABLE images (tile_data BLOB, tile_id TEXT PRIMARY KEY);");
			}
			
			// 3.导入数据
			PreparedStatement mapPs = connection.prepareStatement("insert into map (tile_type, zoom_level, tile_column, tile_row, tile_id) values (?,?,?,?,?);");
			PreparedStatement imagePs = connection.prepareStatement("insert into images (tile_data, tile_id) values (?,?);");
			
			// 根据文件目录找对应文件的过程略,以下为关键代码
			/** 插入文件流,读取数据库文件流的速度明显优于按路径读取文件,且转移方便,适合数据量大、改动性小的文件存储。*/
			try {
				InputStream in = new FileInputStream(file);									
				imagePs.setBinaryStream(1, in,(int) file.length());									
				imagePs.setString(2, tileId);									
				imagePs.addBatch();									
			} catch (FileNotFoundException e1) {								
				e1.printStackTrace();								
			}								
			
			/** 可将多个写操作一并执行,加快写操作,相当于一次捆绑编辑,此方法返回值整型数组,其长度为操作成功的个数,其中一个写操作异常SQLiteException,接下来的写操作不执行,且在方法内异常,无返回值*/
			imagePs.executeBatch();
			// imagePs.clearBatch();
			// 可加入事务操作,相当于一次捆绑保存
			connection.commit();
			// 原子有误,可加入自己的操作,如回退,相当于一次捆绑撤销
			connection.rollback();
			

			//4.读取图片
  			PreparedStatement ps1 = null;
  			ResultSet resultSet = null;
  			try{
  	            String sql = "select tile_data from images";
  	            ps1 = connection.prepareStatement(sql);
  	            InputStream in = null;
  	            resultSet = ps1.executeQuery();           
  	            if(resultSet.next())
  	                in = resultSet.getBinaryStream(1);
  	            fos.close();
  	        }catch(Exception ex){
  	            ex.printStackTrace();
  	        }finally{
  	            try{
  	                if(resultSet != null) resultSet.close();
  	                if(ps1 != null) ps1.close();
  	                if(connection !=null) connection.close();
  	            }catch(Exception ex){
  	                ex.printStackTrace();
  	            }
  	        }

		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			e.printStackTrace();
		}

	}
}

Json+XML+Excel+DBFile相关的Jar包及关键操作代码:
https://download.csdn.net/download/haoranhaoshi/10889219

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风铃峰顶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值