简单分析Hibernate读取Clob
创始人
2024-06-08 03:21:22
0

本文向大家介绍Hibernate读取Clob,可能好多人还不了解Hibernate读取Clob,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

Hibernate虽然对多种数据库进行了适应,以达到前台感受不到后台的数据库类型 ,但是在 Blob 和 Clob 这两种类型的存取方面不同的数据库有不同的实现方法,这方面Hibernate就实在没办法了,在 mssql 中还好实现起来比较简单,但是我现在要说的是 超级麻烦的Oracle ,我做的项目采用的数据库就是Oracle ,不容质疑Oracle的确是***的数据库,但是有些地方太复杂。

使用Hibernate读取Clob 和 Blob 是跟往常一样的,主要是保存。

具体的流程如下:

1、先创建一个只有一个字节的 Blob

2、使用flush 方法强势Hibernate保存这个只有一个字节的 Blob

3、通过保存获得了一个游标

4、使用这个游标来保存真正的数据,对数据库实施 update 操作

具体实现代码如下:

  1. TUser user = new TUser();  
  2. user.setImage(Hibernate.createBlob(new byte[1]));  
  3.  
  4. Transaction ex = session.beginTransaction();  
  5. session.save(user);  
  6. //强制保存这个blob  
  7. session.flush();  
  8. //通过刷新 user 来获得blob游标  
  9. session.refresh(user,LockMode.UPGRADE);  
  10.  
  11. //写入真正的实际内容  
  12. oracle.sql.BLOB blob = (oracle.sql.BLOB)user.getImge();  
  13. OutputStream out = blob.getBinaryOutputStream();  
  14.  
  15. FileInputStream img = new FileInputStream("c:\aaa.jpg");  
  16. byte[] buf = new byte[10240];  
  17. int len;  
  18. while((len = img.read(buf)) > 0)  
  19. ...{  
  20. out.write(buf,0,len);  
  21. }  
  22. img.close();  
  23. out.close();  
  24.  
  25. tx.commit(); 

Hibernate读取Clob也是一样的,只是创建的是一个空格的 String :user.setResume(Hibernate.createClob(" "));

【编辑推荐】

  1. 简单描述Hibernate单元测试
  2. 概括Hibernate多表关联查询
  3. 浅谈Hibernate Session Factory
  4. 浅析Hibernate加载配置文件
  5. 深入剖析Hibernate核心接口

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...