Blob存储实践

/**
 * @author Kevin 2018-1-16
 * 
 * Blob(二进制大对象)对象的存储 jdbc实现。
 *
 */
public class BlobObjectDemo {

	public static void main(String[] args) throws IOException {
		try {
			Class.forName("oracle.jdbc.driver.OracleDriver");
		} catch (ClassNotFoundException e1) {
			e1.printStackTrace();
		}
        Connection conn = null;
        Statement state = null;
        ResultSet rs = null;
        
		try {
			conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "demo", "demo");
			
			state = conn.createStatement();
			String id = UUID.randomUUID().toString().replace("-", "");
			String insertSql = "insert into test_blob values('"+id+"',empty_blob())";
			state.execute(insertSql);
			
			File f = new File("D:\\壁纸\\12 (1).jpg");
			FileInputStream in = new FileInputStream(f);
			
			String sql = "select * from test_blob where id='"+id+"' for update";
			
			rs = state.executeQuery(sql);
			
			while(rs.next()){
				Blob b = rs.getBlob(2);
				OutputStream out = b.setBinaryStream(0);
				byte[] bytes = new byte[in.available()];
				int len = 0;
				while((len = in.read(bytes)) != -1){
					out.write(bytes, 0, len);
				}
			}
			
		} catch (SQLException e) {
			System.err.println("出错回滚");
			e.printStackTrace();
			try {
				conn.rollback();
			} catch (SQLException e1) {
				e1.printStackTrace();
			}
		} finally{
			try {
				rs.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			
			try {
				state.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			
			try {
				conn.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
	}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值