`

Hibernate Transformers之三种结果转换说明

阅读更多

在hibernate使用的过程中.我们通常需要对结果进行解释. 
Hibernate为我们提供了以下3种解释方法: 

Java代码  收藏代码
  1. Transformers.ALIAS_TO_ENTITY_MAP //把输出结果转换成map  
  2. Transformers.TO_LIST //把结果按顺序排进List  
  3. ransformers.aliasToBean(target) //把结果通过setter方法注入到指定的对像属性中  


在Hibernate中Transformers的所有转换都是需要实现ResultTransformer接口 

详解ALIAS_TO_ENTITY_MAP ,太简单了就是把key和值直接转换到Map当中 

Java代码  收藏代码
  1. public Object transformTuple(Object[] tuple, String[] aliases) {  
  2.         Map result = new HashMap(tuple.length);  
  3.         for ( int i=0; i<tuple.length; i++ ) {  
  4.             String alias = aliases[i];  
  5.             if ( alias!=null ) {  
  6.                 result.put( alias, tuple[i] );  
  7.             }  
  8.         }  
  9.         return result;  
  10.     }  


详解TO_LIST,转换过程很简单,就是把value转换成List对像 

Java代码  收藏代码
  1. public Object transformTuple(Object[] tuple, String[] aliases) {    
  2.     return Arrays.asList( tuple );    
  3. }   


详解aliasToBean,转换过程就是通过读取查询后的字段.然后通过使用setter方法注入到目标对像中 

Java代码  收藏代码
  1. public AliasToBeanResultTransformer(Class resultClass) {    
  2.         if ( resultClass == null ) {    
  3.             throw new IllegalArgumentException( "resultClass cannot be null" );    
  4.         }    
  5.         this.resultClass = resultClass;    
  6.         //定义属性访问器.    
  7.         propertyAccessor = new ChainedPropertyAccessor(    
  8.                 new PropertyAccessor[] {    
  9.                         PropertyAccessorFactory.getPropertyAccessor( resultClass, null ),    
  10.                         PropertyAccessorFactory.getPropertyAccessor( "field" )    
  11.                 }    
  12.         );    
  13.     }    
  14.     
  15.     public Object transformTuple(Object[] tuple, String[] aliases) {    
  16.         Object result;    
  17.     
  18.         try {    
  19.             if ( setters == null ) {    
  20.                 setters = new Setter[aliases.length];    
  21.                 for ( int i = 0; i < aliases.length; i++ ) {    
  22.                     String alias = aliases[i];    
  23.                     if ( alias != null ) {    
  24.                         //初始指定的setter方法    
  25.                         setters[i] = propertyAccessor.getSetter( resultClass, alias );    
  26.                     }    
  27.                 }    
  28.             }    
  29.             //实例实体对像    
  30.             result = resultClass.newInstance();    
  31.     
  32.             for ( int i = 0; i < aliases.length; i++ ) {    
  33.                 if ( setters[i] != null ) {    
  34.                     //向setter方法中指定的属性注入值    
  35.                     setters[i].set( result, tuple[i], null );    
  36.                 }    
  37.             }    
  38.         }    
  39.         catch ( InstantiationException e ) {    
  40.             throw new HibernateException( "Could not instantiate resultclass: " + resultClass.getName() );    
  41.         }    
  42.         catch ( IllegalAccessException e ) {    
  43.             throw new HibernateException( "Could not instantiate resultclass: " + resultClass.getName() );    
  44.         }    
  45.     
  46.         return result;    
  47.     }   
分享到:
评论

相关推荐

    hibernate将本地SQL查询结果封装成对象

    总结起来,Hibernate的本地SQL查询功能为我们提供了一种灵活的方式来执行复杂的数据库操作,同时通过`addEntity()`、`addScalar()`和`Transformers.aliasToBean()`等方法,我们可以方便地将查询结果封装成Java对象,...

    hibernate将本地SQL查询结果封装成对象(最终).zip

    - 如果查询结果中包含多张表的数据,可以使用`setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)`将结果转换为Map,键为列名,值为对应列的值。 通过理解并掌握以上内容,开发者可以有效地利用Hibernate将...

    Hibernate中Sql语句

    在本例中,使用了`addScalar`方法指定结果集中的列名及其对应的Java类型,并使用`setResultTransformer`设置结果转换器为`Transformers.aliasToBean(SumPlace.class)`。 ```java query1.addScalar("productSum", ...

    hibernate3中通过nativesql或取部分字段并映射为具体对象的实现

    另一种方式是使用`setResultTransformer()`,它可以自动将结果转换为我们想要的对象类型。这里我们可以使用`Transformers.aliasToBean(User.class)`: ```java query.setResultSetTransformer(Transformers....

    Criteria hibernate

    查询结果通常是一个List,但我们可以使用Transformers类的实例化方法,如asList(), asScalar()等,来转换结果集。 10. **源码分析** 对于深入理解Criteria API的工作原理,查看和分析其源码是非常有价值的。通过...

    Criteria(hibernate3.0).rar_Criteria java_criteria Hibernate_hibe

    还可以通过`Transformers`将查询结果转换为特定的对象,如`as(Class clazz)`可以将结果转换为指定类型的列表。 六、动态Criteria 动态Criteria允许我们在运行时构建查询,通过`createCriteria(String propertyName...

    Hibernate深入研究之Criteria.rar

    通过`setResultTransformer()`可以自定义结果转换,例如`Transformers.aliasToBean()`可以直接将查询结果转换为Java Bean。 9. **分页查询**:Criteria API同样支持分页查询,通过`setFirstResult()`和`...

    hibernate3使用手册

    - Projections和Criteria Transformers:用于查询结果的转换,如计算平均值、计数等。 7. **实体和持久化类** - 实体类:用注解@Entity标识,表示一个数据库表。 - 属性映射:@Id标识主键,@Column定义列属性,@...

    Hibernate最新中文帮助文档

    12. **查询结果集转换**:Hibernate提供了`Transformers`类,可以将查询结果转换为自定义对象,方便数据处理。 13. ** Criteria API的子查询**:Criteria API支持创建子查询,可以嵌套在父查询中,实现复杂的数据...

    [原]在MyEclipse中开发Hibernate入门

    - 使用Hibernate的Transformers工具类可以将结果转换为自定义类型。 8. **延迟加载和级联操作** - 延迟加载(Lazy Loading)允许只在需要时加载关联对象,提高性能。 - 级联操作(Cascade)可以在一个对象被操作...

    Hibernate中Criteria的使用

    8. **结果集转换(Transformers)**:可以将Criteria查询的结果转换为自定义的对象列表,如List、Map等。例如,将结果转换为Map列表: ```java List, Object&gt;&gt; result = criteria.setResultTransformer...

    关联映射hibernate的criteria的用法

    例如,`Transformers.aliasToBean(User.class)`将结果转换为User对象列表。 ```java criteria.setProjection(Projections.projectionList() .add(Projections.property("id")) .add(Projections.property("name")...

    Hibernate Criteria 完全使用

    Hibernate Criteria API 是 Hibernate 框架中一个强大的查询工具,它提供了一种面向对象的方式来构建SQL查询,使得开发者无需直接编写SQL语句,即可进行复杂的数据库操作。Criteria API 提供了高度抽象的接口,可以...

    Query对象setResultTransFormer()

    Transformers.ALIAS_TO_ENTITY_MAP 是 Hibernate 中的一个转换器,用于将查询结果转换为 Map 对象。ALIAX_TO_ENTITY_MAP Transformer 将查询结果转换为 Map 对象,KEY 是数据库中的字段名,VALUE 是该字段的值。 ...

    flexjson-2.1.zip

    5. **自定义转换(Custom Transformers)**:Flexjson允许注册自定义的转换器,以便在序列化或反序列化过程中自定义特定类型的处理方式。 6. **动态模型(Dynamic Models)**:如果你不知道具体的数据结构,可以...

    NHibernate 执行存储过程

    这段代码会执行`usp_GetEmployees`存储过程,并将结果转换为Employee对象的列表。 **处理输出参数和返回值** 如果存储过程有输出参数或返回值,我们需要在调用时显式处理。例如,一个存储过程可能有一个输入参数`@...

    让JPA的Query查询接口返回Map对象的方法

    Hibernate的.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)。 因此,如果我们想要返回Map并且确定底层用的是某一种JPA的实现时,我们可以退而求其次,牺牲跨实现的特性来满足我们的需求: ```java ...

Global site tag (gtag.js) - Google Analytics