快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

在Java中使用Oracle blob

Oracle中的lob (Large Object)可以存储异常大的数据(可能是4GB),这样就可以通过将文件或其它任何对象序列化成字节输出流(OutputStream)后写入数据库,之后使用字节输入流(InputStream)将数据读出然后反序列化为原始文件或对象。操作时需要使用oracle的JDBC包,它扩展了sun的JDBC包中的Blob对象。同时需要注重一些细节。下面的代码演示如何使用blob(实例中需要Oracle的JDBC包)。

import oracle.jdbc.OracleResultSet; // 使用Oracle的ResultSet对象
import oracle.sql.BLOB; // 使用Oracle的BLOB对象,而不是sun的Blob

...

try{
Connection conn=<数据库连接>;
File file=<存入数据库的文件对象>;
conn.setAutoCommit(false); // 取消Connection对象的auto commit属性
String file_name=file.getName();

// 数据库中有一个item表,其中的file_name (varchar2)存储文件名,file_blob (blob)存储文件对象
String sql="INSERT INTO item (file_name,file_blob) VALUES (\\\'" + file_name + "\\\',EMPTY_BLOB())"; // 使用“EMPTY_BLOB()“成生一个空blob
Statement stmt=conn.createStatement();
int count=stmt.executeUpdate(sql);

sql="SELECT file_blob FROM item WHERE iid=\\\'" + iid + "\\\' FOR UPDATE"; // 使用“FOR UPDATE”得到表的写锁
ResultSet rs=stmt.executeQuery(sql);
rs.next();
BLOB blob=((OracleResultSet)rs).getBLOB("file_blob"); // 得到BLOB对象
OutputStream out=blob.getBinaryOutputStream(); // 建立输出流
InputStream in=new FileInputStream(file); // 建立输入流
int size=blob.getBufferSize();
byte[] buffer=new byte[size]; // 建立缓冲区
int len;
while((len=in.read(buffer)) != -1)
out.write(buffer,0,len);
in.close();
out.close();

conn.commit();
}
catch(Exception ex){
try{
conn.rollback();
}
catch(SQLException sqle){
System.err.println(sqle.getMessage());
}
}

假如要读出文件的话只需调用BLOB的getBinaryStream()生成一个输入流,再写入一个文件就行了。






返回类别: 教程
上一教程: 转-如何学习java
下一教程: 常用JAVA方式

您可以阅读与"在Java中使用Oracle blob"相关的教程:
· 避免在Java中使用Checked Exception
· Java Swing中使用双击事件
· 在JAVA中使用正则表达式
· 在JSP中使用JAVAMAIL
· 企业内部网中使用POLICY文件来设置JAVA的安全策略
    微笑服务 优质保证 索取样品