- 浏览: 886161 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (687)
- java (127)
- servlet (38)
- struts (16)
- spring (22)
- hibernate (40)
- javascript (58)
- jquery (18)
- tomcat (51)
- 设计模式 (6)
- EJB (13)
- jsp (3)
- oracle (29)
- RUP (2)
- ajax (3)
- java内存管理 (4)
- java线程 (12)
- socket (13)
- path (5)
- XML (10)
- swing (2)
- UML (1)
- JBPM (2)
- 开发笔记 (45)
- Note参考 (15)
- JAXB (4)
- Quartz (2)
- 乱码 (2)
- CSS (2)
- Exception (4)
- Tools (7)
- sqlserver (3)
- DWR (7)
- Struts2 (47)
- WebService (2)
- 问题解决收藏 (7)
- JBOSS (7)
- cache (10)
- easyUI (19)
- jQuery Plugin (11)
- FreeMarker (6)
- Eclipse (2)
- Compass (2)
- JPA (1)
- WebLogic (1)
- powerdesigner (1)
- mybatis (1)
最新评论
-
bugyun:
受教了,谢谢
java 正则表达式 过滤html标签 -
xiongxingxing_123:
学习了,感谢了
java 正则表达式 过滤html标签 -
wanmeinange:
那如果无状态的。对同一个任务并发控制怎么做?比如继承Quart ...
quartz中参数misfireThreshold的详解 -
fanjieshanghai:
...
XPath 元素及属性查找 -
tianhandigeng:
还是没明白
quartz中参数misfireThreshold的详解
Photo.java
- import java.sql.Blob;
- import java.sql.Clob;
- import java.util.Date;
- /**
- * @author IBM 这是一个用于测试Hibernate大对象操作的PO
- *
- * 这是一个测试POJO, 属性有多种类型
- */
- public class Photo {
- private Long id;
- private String fileName="";// 文件名
- private Date date = new Date(); // 主库时间,默认值是当前时间
- private Blob photo;// 相片的二进制形式,大对象
- private Clob text;// 文字说明,大对象
- private byte[] bin;//字节数组
- }
import java.sql.Blob; import java.sql.Clob; import java.util.Date; /** * @author IBM 这是一个用于测试Hibernate大对象操作的PO * * 这是一个测试POJO, 属性有多种类型 */ public class Photo { private Long id; private String fileName="";// 文件名 private Date date = new Date(); // 主库时间,默认值是当前时间 private Blob photo;// 相片的二进制形式,大对象 private Clob text;// 文字说明,大对象 private byte[] bin;//字节数组 }
Photo.hbm.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping package="test.com.base">
- <class name="Photo" table="test_Photo">
- <id name="id">
- <generator class="native"/>
- </id>
- <property name="fileName" />
- <property name="date" />
- <property name="photo" />
- <property name="text" />
- <property name="bin" />
- </class>
- </hibernate-mapping>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="test.com.base"> <class name="Photo" table="test_Photo"> <id name="id"> <generator class="native"/> </id> <property name="fileName" /> <property name="date" /> <property name="photo" /> <property name="text" /> <property name="bin" /> </class> </hibernate-mapping>
PhotoManagerImpl.java
其中继承了BaseDao类,这是一个通用Hibernate 泛型DAO工具类
- package test.com.base;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.io.Reader;
- import java.nio.CharBuffer;
- import java.sql.Clob;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import com.base.dao.BaseDao;
- @Transactional
- @Service
- public class PhotoManagerImpl extends BaseDao<Photo,Long> {
- //空
- }
package test.com.base; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.io.Reader; import java.nio.CharBuffer; import java.sql.Clob; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.base.dao.BaseDao; @Transactional @Service public class PhotoManagerImpl extends BaseDao<Photo,Long> { //空 }
BaseDaoBlobClobTest.java
其中用到了JUnitBase_svc类,作用是加载spring的配置文件
- package test.com.base;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.io.Reader;
- import java.sql.Blob;
- import java.sql.Clob;
- import javax.annotation.Resource;
- import org.hibernate.Hibernate;
- import org.hibernate.LockMode;
- import org.hibernate.Session;
- import org.hibernate.Transaction;
- import org.junit.Test;
- import com.base.dao.BaseDao;
- /**
- * 通过个单元测试,演示了<br/>
- * 1: 如何操作大象<br/>
- * 2:懒加载的一种解决方案<br/>
- */
- public class BaseDaoBlobClobTest extends JUnitBase_svc {
- @Resource
- private PhotoManagerImpl photoManagerImpl;
- /**
- * 测试保存大对象
- */
- @Test
- public void TestSaveBlob() {
- // ----------456.jpg 转成Blob--------------------
- InputStream in = this.getClass().getResourceAsStream("phtot.jpg");
- Blob blob = null;
- try {
- blob = Hibernate.createBlob(in);
- } catch (IOException e) {
- e.printStackTrace();
- }
- // ----------文字 转成Clob--------------------
- Clob clob = Hibernate.createClob("文字 转成Clob");
- // ------------------------------------------
- Photo photo = new Photo();
- photo.setFileName("haha.jpg");
- photo.setPhoto(blob);
- photo.setText(clob);
- photoManagerImpl.save(photo);
- }
- /**
- * 测试取得大对象,没有使用懒加载,
- */
- @Test
- public void TestGetBlob() {
- Photo photo = photoManagerImpl.get(3L);// 执行Hibername的get方法,会马上执行SQL查询
- int len = 0;
- byte[] buf = new byte[1024];
- try {
- String path = "d:\\abc.jpg";// 取出图片后保存的位置
- InputStream in = photo.getPhoto().getBinaryStream();
- OutputStream out = new FileOutputStream(new File(path));
- while ((len = in.read(buf)) > 0) {
- out.write(buf, 0, len);
- }
- out.close();
- in.close();
- System.out.println("读出的图片放在了:" + path);
- Clob clob = photo.getText();
- Reader reader = clob.getCharacterStream();
- char[] cb = new char[1024];
- StringBuffer sb = new StringBuffer();
- len = 0;
- while ((len = reader.read(cb)) > 0) {
- sb.append(cb, 0, len);
- }
- System.out.println(sb.toString());
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /**
- * 测试取得大对象,使用了懒加载,
- *
- * 并且是在事务已提交,session已关闭后才通过Hibernate代理查出的目标对象
- *
- * 这是懒加载的一种解决方案,很重要,特此说明
- */
- @Test
- public void TestLoadBlob() {
- // 执行的是load方法,会延迟加载,返回Hibernate代理对象之后session已关闭
- Photo photo = photoManagerImpl.load(3L);
- //打开一个新Session,不能使用getCurrentSession()方法
- Session session = photoManagerImpl.getNewSession();
- System.out.println("Session是打开的吗:"+session.isOpen());
- // 把Hibernate代理对象重新关联到一个session对象
- session.lock(photo, LockMode.NONE);
- //开启事务
- Transaction t=session.beginTransaction();
- int len = 0;
- byte[] buf = new byte[1024];
- try {
- String path = "d:\\abc.jpg";// 取出图片后保存的位置
- //这时才发出sql语句,执行查询,达到了懒加载的目的
- InputStream in = photo.getPhoto().getBinaryStream();
- OutputStream out = new FileOutputStream(new File(path));
- while ((len = in.read(buf)) > 0) {
- out.write(buf, 0, len);
- }
- out.close();
- in.close();
- System.out.println("读出的图片放在了:" + path);
- Clob clob = photo.getText();
- Reader reader = clob.getCharacterStream();
- char[] cb = new char[1024];
- StringBuffer sb = new StringBuffer();
- len = 0;
- while ((len = reader.read(cb)) > 0) {
- sb.append(cb, 0, len);
- }
- ;
- System.out.println(sb.toString());
- } catch (Exception e) {
- e.printStackTrace();
- }
- System.out.println(t==session.getTransaction());
- //提交事务
- session.getTransaction().commit();
- //关闭
- session.close();
- }
- }
发表评论
-
Criteria查询,DetachedCriteria离线查询 --做综合查询
2011-09-06 00:25 1591通过Session得到Criteria类的对象 Ja ... -
Hibernate批量操作(JDBC批量操作)
2011-09-06 00:24 1290部分内容转自 :http://ga ... -
Hibernate懒加载深入分析
2011-09-06 00:19 1321懒加载可以提高性能吗? 不可以简单的说"能" ... -
getSesson currentSession
2011-09-06 00:15 9981 getCurrentSession创建的session会和 ... -
Hibernate建表错误,Could not determine type for: java.util.List
2011-04-04 22:19 1638今天遇到 Could not determine type f ... -
Hibernate的fetch="join"和fetch="select"
2011-03-24 14:16 966fetch参数指定了关联对 ... -
Hibernate的Criteria用法总结
2011-03-23 10:53 774最近在项目中使用 Struts 和 Hibernate 进行开 ... -
第29讲--为Spring集成的Hibernate配置二级缓存
2011-03-10 23:16 1098合理的使用缓存策略,往往在web开发中提高性能起到关键作用。 ... -
hibernate抓取策略
2011-02-12 13:23 816Hibernate最让人头大的就是对集合的加载形式。书看了N次 ... -
Hibernate笔记:HQL查询总结(一)——简单属性查询和实体对象查询
2011-02-01 23:38 3488本文一部分转自kuangbaoxu的博文hibernate-- ... -
Hibernate笔记:HQL查询总结(二)——条件查询
2011-02-01 23:35 1505条件查询 1.拼字符串 where条件后面,可以用字 ... -
Hibernate属性延迟加载
2011-02-01 21:28 1009Hibernate3开始增加了通过property节点的la ... -
Hibernate中的cascade和inverse
2011-01-31 00:31 991这两个属性都用于一多对或者多对多的关系中。而inverse特别 ... -
batch_size 和 fetch_size作用
2010-12-01 21:37 1277hibernate抓取策略,,batch-szie在< ... -
hibernate中SQLQuery的addEntity();方法
2010-10-20 10:48 2767如果使用原生sql语句进行query查询时,hibernate ... -
Hibernate的evict方法错误总结
2010-10-14 10:08 1207摘自百度知道:http://zhi ... -
hibernate中get方法和load方法的区别
2010-10-14 09:57 798键字: hibernate get load 区 ... -
Hibernate: 设A引用了B,则删A后可能要evict(A.getB())
2010-10-14 09:56 999Hibernate: 设A引用了B,如果要先取A删A再取B删B ... -
Hibernate的flush()和evict()总结
2010-10-14 09:53 1321关键字: hibernate flush() evict() ... -
flush,commit,evict
2010-10-14 09:52 919Flush()后只是将Hibernate缓存中的数据提交到数据 ...
相关推荐
同时,确保数据库支持高效的BLOB和CLOB操作,比如Oracle的BFILE类型或使用流式处理。 总之,Hibernate提供了对BLOB和CLOB的便利支持,允许开发者在Java应用中轻松地处理大数据对象,从而实现与数据库的高效交互。...
在Java中,Blob和Clob是JDBC API提供的接口,但在Hibernate中,我们可以通过Session对象的save()或saveOrUpdate()方法来操作这些大数据对象。 首先,我们需要在实体类中定义对应的属性。例如,对于一个包含图片信息...
在Java Web开发中,...本文将详细介绍如何在Hibernate中操作Blob和Clob字段,实现数据的存储与读取。 首先,我们需要在Hibernate映射文件(.hbm.xml)中定义Blob和Clob字段。对于Blob,可以这样声明: ```xml ...
hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan
这篇博客文章“Hibernate操作Oracle中Clob、Blob字段小结”可能会探讨如何在Hibernate中有效地处理这两种类型的数据。 1. **Clob与Blob的理解**: - Clob:Clob是用于存储大量字符数据的类型,例如长篇文章、XML...
在保存或更新带有Clob和Blob字段的实体时,Hibernate会自动处理这些数据的插入和更新操作。例如,当你调用`session.saveOrUpdate(entity)`或`entityManager.persist(entity)`时,Hibernate会将Clob和Blob的内容正确...
综上所述,使用Hibernate和JDBC读取Oracle数据库中的Blob数据涉及多个步骤,包括实体类的设计、数据库操作和文件流的处理。理解这些知识点对于处理大对象存储至关重要。在实际项目中,根据需求和性能考虑,选择合适...
Blob imageData = Hibernate.createBlob(fis); // 或者使用数据库驱动提供的Blob实现 Blob imageData = connection.createBlob(); imageData.setBinaryStream(1, fis, (int) imageFile.length()); ``` 4. **...
这篇博客“使用Jdbc4操作Blob,Clob”将深入讲解如何利用JDBC4 API来处理Blob和Clob对象。 Blob通常用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储大量文本数据,如长篇的文本或XML文档。在JDBC4中...
### Spring与Hibernate处理大字段(CLOB/BLOB) 在企业级应用开发中,经常会遇到需要存储大量文本或二进制数据的情况,这时就需要用到数据库的大字段类型如CLOB(Character Large Object)和BLOB(Binary Large ...
在本示例中,我们将探讨如何使用Oracle数据库、Hibernate ORM框架以及Uploadify插件处理Blob类型的大数据,如图片或文件上传。Blob(Binary Large Object)是数据库中用于存储二进制大对象的类型,常用于存储图片、...
Spring和Hibernate框架结合使用可以有效地进行CLOB字段的操作。以下是实现这一功能的关键步骤和注意事项: 1. **配置SessionFactory** 在Spring配置文件中,你需要创建一个`SessionFactory` bean,同时指定一个`...
- 使用Blob/Clob接口:直接操作Clob接口进行读写,而不是将其转换为字符串或其他数据类型,以减少转换开销。 通过以上内容,你应该对在Hibernate中动态映射Oracle 10g的CLOB类型有了深入理解,这将帮助你在实际...
总结来说,Blob和Clob是数据库中存储大对象的关键工具,它们在Hibernate中提供了方便的接口用于操作这些数据。在Microsoft SQL Server环境下,Hibernate能够无缝地将Java对象与Blob和Clob类型的数据库字段对应起来,...
2. **预编译SQL语句**:Blob和Clob操作通常涉及预编译的PreparedStatement,因为它们通常需要动态插入或更新大数据值。例如,`PreparedStatement.setBlob(int index, Blob value)` 和 `PreparedStatement.setClob...
此外,还要注意数据库的性能,比如使用BLOB而非CLOB,根据数据的性质选择更合适的存储方式。 总的来说,理解和掌握Clob在Hibernate中的应用对于开发处理大文本数据的系统至关重要。通过合理的配置和使用,可以有效...