create table users
(
uids int primary key,
img blob,
txt clob
)
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.io.Writer;
import java.sql.Clob;
import java.sql.SQLException;
import java.util.List;
import oracle.sql.CLOB;
import org.hibernate.Hibernate;
import org.hibernate.HibernateException;
import org.hibernate.LockMode;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.lob.SerializableBlob;
import org.hibernate.lob.SerializableClob;
import com.yl.hibernater.bean.Users;
/**
* Hibernate3.1+classes12.jar(oracle)
*
* 我的想法是:在oracle中创建一张表包含BLOB,CLOB字段。刚开始这样做的。
* 后来跟Hibernate映射的时候*.hbm.xml文件中老是默认的创建了复合主键,网上查了,映射的时候必须要一个主键字段。
*
* 说明下 POJO 与 xml 文件中的数据类型都是java.sql.Blob与java.sql.Clob
* BLOB放图片
* CLOB放大型文本
*
* 在做这个例子的时候,类型的转化真的有点晕。 呵呵
*
* @author YouLong
* @date 2009.6.18
*/
public class Text
{
@SuppressWarnings("unchecked")
public static void main(String[] args)
{
Configuration hf = HibernateSessionFactory.getConfiguration();
SessionFactory hsf = hf.buildSessionFactory();
Session session = hsf.openSession();
Transaction ta = session.beginTransaction();
try
{
Users u = new Users();
u.setUids(1);
u.setImg(Hibernate.createBlob(new byte[1])); //这里相当于在内存添加的默认值
u.setTxt(Hibernate.createClob(new String("1")));//这里相当于在内存添加的默认值
session.save(u);//保存不提交
session.flush();//强制执行insert
session.refresh(u,LockMode.UPGRADE); //给表上锁
//开始读文件内容,并写入BLOB字段
FileInputStream fis = new FileInputStream("E:\\workspace\\YL\\src\\com\\yl\\socket\\blogjava\\output.jpg");
SerializableBlob bb = (SerializableBlob) u.getImg(); // 先从java.sql.Blob转SerializableBlob
java.sql.Blob blob = bb.getWrappedBlob(); //再从通过getWrappedBlob()这个方法又转为java.sql.Blob,这里实在不理解
if(blob instanceof oracle.sql.BLOB)//判断类型
{
oracle.sql.BLOB ob = (oracle.sql.BLOB)blob;// 从java.sql.Blob转oracle.sql.BLOB
OutputStream writer = ob.getBinaryOutputStream();
byte [] b = new byte[102400];
int len = 0;
while((len=fis.read(b))!=-1)
{
writer.write(b, 0, len);
}
fis.close();
writer.close();
}
//开始读文件内容,并写入CLOB字段
SerializableClob sclob = (SerializableClob) u.getTxt();
Clob clob = sclob.getWrappedClob();
if(clob instanceof oracle.sql.CLOB)
{
oracle.sql.CLOB cc = (CLOB) clob;
Writer w = cc.getCharacterOutputStream();
w.write("YOULONG IS GOOD!!");
w.close();
}
ta.commit();//向数据库提交事务,再查询
Query query = session.createQuery("from Users");
List<Users> list = query.list();
for (int i = 0; i < list.size(); i++)
{
Users us = (Users)list.get(i);
SerializableBlob ub = (SerializableBlob) us.getImg();
java.sql.Blob ib = ub.getWrappedBlob();
if(ib instanceof oracle.sql.BLOB)
{
InputStream in = ib.getBinaryStream();
FileOutputStream fos = new FileOutputStream("c:/a.jpg"); //向外面生成图片
byte [] by = new byte[102400];
int j = 0;
while((j=in.read(by))!=-1)
{
fos.write(by, 0, j);
}
in.close();
fos.close();
}
SerializableClob sb = (SerializableClob)us.getTxt();
java.sql.Clob ic = sb.getWrappedClob();
if(ic instanceof oracle.sql.CLOB)
{
oracle.sql.CLOB cb = (oracle.sql.CLOB)ic;
System.out.println(cb.getSubString(1, (int) cb.length()));
}
}
} catch (HibernateException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally{
session.close();
}
}
}
分享到:
相关推荐
使用Hibernate映射Blob,Clob字段,并对这些字段完成存,取功能
hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan
NULL 博文链接:https://sxpujs.iteye.com/blog/368960
oracle的jdbc驱动程序,用这个版本的操作Clob,blob类型的数据很方便。 博文链接:https://zhenjw.iteye.com/blog/173419
用hibernate和jdbc读存blob或clob
oracle+hibernate 处理blob +uploadify实例 结合了 uploadify 上传给件实例 如有需要的可以下载 文件上传组件 Uploadify-3.1-Demo实例详解 文档查看 都是免费的
NULL 博文链接:https://sjsky.iteye.com/blog/1154916
在hibernate+microsoft sqlserver中使用Blob,和Clob,
是我自己验证过的 用的是oracle10数据库 文件里面有具体的配置。
主要介绍了详解jdbc实现对CLOB和BLOB数据类型的操作的相关资料,这里实现写入操作与读写操作,需要的朋友可以参考下
J2EE开发中,经常会遇到存储大文本的文字信息,而oracle数据库的vachar字段最大能存储4000个字节,存储更大的信息必须使用clob或blob字段,本文档就是针对j2ee开发中对colb字段操作的实现。
本篇是对使用jdbc,hibernate处理clob/blob字段进行了详细的分析介绍,需要的朋友参考下
一个完整的工程,主要功能为:spring+hbernate对clob、blob字段的处理 包括:数据脚本、典型的SSH框架处理,以及spring、hibernate数据批量保存等功能源码、所用到的lib包 数据环境为:oracle 10G 开发:Mycelipse5.1...
这种做法不必处理clob(Character Large Object), blob(Binary Large Object)等格式的字段类型,但不易做transaction的控制,而且增加了对文件的处理操作,不算是较佳的一个方案。另一个做法是使用clob, blob等字段...
11.3 操纵Blob和Clob类型数据 11.4 小结 11.5 思考题 第12章 映射继承关系 12.1 继承关系树的每个具体类对应一个表 12.1.1 创建映射文件 12.1.2 操纵持久化对象 12.2 继承关系树的根类对应一个表 ...