mysql blob hibernate_Hibernate保存Blob和Clob类型的数据

虽然非常不建议在数据库中保存Blob和Clob类型的数据,但真的要有这样的需求呢?这里记录一下使用Hibernate如何向数据库中保存Blob和Clob数据。

Oracle和MySql在Blob类型上没什么区别,但是Mysql没有Clob类型,取而代之的是Text类型,所以这里还有点区别。BLOB在数据库中是以二进制的形式存在的,所以无法直接看到,如果是图片的话,使用一些数据库管理软件还是可以看到图片的,而CLOB就是大文本,可以直接就看到内容。

Oracle

这是一个名为Student的实体类:

packagecn.entity;importjava.sql.Blob;importjava.sql.Clob;public classStudent {privateString stuid;privateBlob stuimage;privateClob studesc;/*setter and getter*/}

Student.hbm.xml:

使用Hibernate操作CLOB和BLOB:

@Testpublic voidsaveBlobAndClob() {try{//123.jpg

InputStream in=new FileInputStream("d:\\123.jpg");byte[] byteArray=new byte[in.available()];

in.read(byteArray);

in.close();//新建文本文档.txt

InputStream in2=new FileInputStream("d:\\新建文本文档.txt");byte[] byteArray2=new byte[in2.available()];

in2.read(byteArray2);

in2.close();

String string=newString(byteArray2);

User user=newUser();user.setPhoto(Hibernate.createBlob(byteArray));

user.setInfo(Hibernate.createClob(byteArray2));

session.save(user);

}catch(Exception e) {

e.printStackTrace();

}

}

这里主要是使用Hibernate的静态方法createBlob或createClob即可

MySql

mysql中并没有CLOB类型的数据,使用的Text类型,映射的Java类型使用String而不能再使用java.sql.Clob类型,

注意点有两个。

User.java:(注意点一:使用String的Java类型)

packagecn.entity;importjava.sql.Blob;public classUser {privateInteger id;privateBlob photo;privateString info;/*setter and getter*/}

User.hbm.xml:(注意点二:映射类型为text)

要使用text的type,而不是clob的type,不然会映射不成功

使用Hibernate操作CLOB和BLOB的代码和Oracle中的大致一样,不同之处在于使用string操作:

@Testpublic voidsaveBlobAndClob() {try{//123.jpg

InputStream in=new FileInputStream("d:\\123.jpg");byte[] byteArray=new byte[in.available()];

in.read(byteArray);

in.close();//新建文本文档.txt

InputStream in2=new FileInputStream("d:\\新建文本文档.txt");

InputStreamReader reader=new InputStreamReader(in2,"gbk");char[] cbuf=new char[1024];

reader.read(cbuf);

reader.close();

User user=newUser();user.setPhoto(Hibernate.createBlob(in));

user.setInfo(newString(cbuf));

session.save(user);

}catch(Exception e) {

e.printStackTrace();

}

}

读的操作

对于CLOB的读操作使用:

getCharacterStream()

getAsciiStream()

对于BLOB的读操作使用:

getBinaryStream()

getBytes(long pos, int length)

都是对应类中的方法,需要时可以查API,其实使用JDBC也可以操作这两种类型,PreparedStatement中都有对应方法,如

ps.setBinaryStream 操作BLOB

ps.setClob 操作CLOB类型的数据

ps.setAsciiStream 使用流的方式处理CLOB(ASDII编码)

ps.setUnicodeStream 使用流的方式处理CLOB(Unicode编码)

ps.setCharacterStream 使用字符流处理CLOB

所以纯使用JDBC也是可以操作这两种数据类型的

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值