package readclobDemo.bao; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.sql.Blob; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import jdbcutil.bao.JdbcUtil; /** 原理: 在数据库中对Blob(二进制大对象)字段类型进行图片的存储和读取操做,其中Blob做为一个二进制文件的容器,对大数据对象进行处理; 步奏:1。在oracle数据库中建表 CREATE TABLE "HR"."T_IMAGES" ("IMAGEID" NUMBER(*,0) NOT NULL ENABLE, "IMAGE" BLOB, CONSTRAINT "T_IMAGES_PK" PRIMARY KEY ("IMAGEID") ),其中有Blob字段类型,对大对象数据的储存 2.本程序中定义了两个方法,writeBlob()方法主要实现向数据库中储存图片,readerBlob()方法主要实现从数据库中读取存入的图片数据 3.在Main()函数中对两个方法的声明 */ public class WRBlobDemo { Connection conn=null; PreparedStatement pasts=null; ResultSet rs=null; public static void main(String[] args) throws IOException, SQLException { WRBlobDemo a=new WRBlobDemo(); //a.writeBlob(2); a.readBlob(2); } public void writeBlob(int id) throws IOException, SQLException{ String sql1="insert into t_images(imageid,image) values('"+id+"',empty_blob())"; String sql2="select * from t_images where imageid=? for update "; try { conn=JdbcUtil.getConnection(); conn.setAutoCommit(false);//设置为手动提交 pasts=conn.prepareStatement(sql1); pasts.executeUpdate(); System.out.println("图片存储成功!"); pasts=conn.prepareStatement(sql2); System.out.println("图片存储成功!"); pasts.setInt(1, id); rs=pasts.executeQuery(); System.out.println("图片存储成功!"); if(rs.next()){ Blob blob=rs.getBlob("image"); OutputStream out=blob.setBinaryStream(1L); //得到输出流,设置起始节点位置 InputStream in=new FileInputStream("F:\\images\\Img.jpg"); byte[] buffer=new byte[1024]; int lenth; while((lenth=in.read(buffer))>0){ out.write(buffer,0,lenth); } System.out.println("图片存储成功!"); in.close(); out.close(); } conn.commit(); } catch (SQLException e) { try { conn.rollback(); } catch (SQLException e1) { e1.printStackTrace(); } e.printStackTrace(); }finally{ JdbcUtil.free(rs,pasts, conn); } } public void readBlob(int id) throws IOException{ String sql="select * from t_images where imageid=? "; try { conn=JdbcUtil.getConnection(); pasts=conn.prepareStatement(sql); pasts.setInt(1, id); rs=pasts.executeQuery(); if(rs.next()){ Blob blob=rs.getBlob("image"); InputStream in=blob.getBinaryStream(); //读取返回的结果集 OutputStream out=new FileOutputStream("F:\\images\\1.jpg");//将图片读取存放在指定位置 byte[] buffer=new byte[1024]; int lenth; while((lenth=in.read(buffer))>0){ out.write(buffer,0,lenth); } System.out.println("图片读取成功!"); in.close(); out.close(); } } catch (SQLException e) { e.printStackTrace(); }finally{ JdbcUtil.free(rs,pasts, conn); } } }