CLOB等大字段在Hibernate中的处理总结

最近在做一个项目的前台页面展现时要对一个存在Clob大字段实体(UserEntity.java)进行查询操作,考虑到在某些展现页面中是不需要展现大字段的,听过hibernate有对普通属性进行延迟抓取,所以查看了一下Reference,发现配置这个延迟抓取还不简单,需要运行时字节码增强,一看就很晕,在网上查了下资料,就对大字段的查询处理问题,总结了一下,初步有3种实现方案:

      1、使用hibernate的属性延迟抓取,在属性上定义fetch = FetchType.LAZY,然后借助类增强器对二进制Class文件进行强化处理,通过ANT调用Hibernate类增强器对UserEntity.class文件进行强化处理,脚本如下: 

<project name="HibernateSample" default="instrument" basedir=".">
  <property name="lib.dir" value="./lib"/>
  <property name="classes.dir" value="./bin"/>
  
  <path id="lib.class.path">
     <fileset dir="${lib.dir}">
         <include name="**/*.jar"/>
     </fileset>
   
  <target name="instrument">
     <taskdef name="instrument"
         classname="org.hibernate.tool.instrument.InstrumentTask">

        <classpath path="${classes.dir}"/>
        <classpath refid="lib.class.path"/>
     </taskdef>
        
     <instrument verbose="true">
        <fileset dir="${classes.dir}/com/cn/hibernate/db/entity">
           <include name="UserEntity.class"/>
        </fileset>
     </instrument>
  </target>
</project>

 注:脚本中涉及的配置路径,根据项目目录修改。

     2、将UserEntity实体分解成2个实体,UserEntity中不包括Clob属性,UserDetailEntity继续自UserEntity,同时包含Blob属性。 普通查询时候查询UserEntity对象,在处理带有Clog需求的User的时候使用UserDetailEntity对象。

     3、别搞那么复杂,直接写sql进行查询,想要那个字段,自己取那个字段。 
       
   

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值