`

Hibernate Transformers之三种结果转换说明

    博客分类:
  • J2EE
阅读更多
在hibernate使用的过程中.我们通常需要对结果进行解释.
Hibernate为我们提供了以下3种解释方法:
Transformers.ALIAS_TO_ENTITY_MAP //把输出结果转换成map
Transformers.TO_LIST //把结果按顺序排进List
ransformers.aliasToBean(target) //把结果通过setter方法注入到指定的对像属性中

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

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

public Object transformTuple(Object[] tuple, String[] aliases) {
		Map result = new HashMap(tuple.length);
		for ( int i=0; i<tuple.length; i++ ) {
			String alias = aliases[i];
			if ( alias!=null ) {
				result.put( alias, tuple[i] );
			}
		}
		return result;
	}

详解TO_LIST,转换过程很简单,就是把value转换成List对像
public Object transformTuple(Object[] tuple, String[] aliases) {  
    return Arrays.asList( tuple );  
} 

详解aliasToBean,转换过程就是通过读取查询后的字段.然后通过使用setter方法注入到目标对像中
public AliasToBeanResultTransformer(Class resultClass) {  
        if ( resultClass == null ) {  
            throw new IllegalArgumentException( "resultClass cannot be null" );  
        }  
        this.resultClass = resultClass;  
        //定义属性访问器.  
        propertyAccessor = new ChainedPropertyAccessor(  
                new PropertyAccessor[] {  
                        PropertyAccessorFactory.getPropertyAccessor( resultClass, null ),  
                        PropertyAccessorFactory.getPropertyAccessor( "field" )  
                }  
        );  
    }  
  
    public Object transformTuple(Object[] tuple, String[] aliases) {  
        Object result;  
  
        try {  
            if ( setters == null ) {  
                setters = new Setter[aliases.length];  
                for ( int i = 0; i < aliases.length; i++ ) {  
                    String alias = aliases[i];  
                    if ( alias != null ) {  
                        //初始指定的setter方法  
                        setters[i] = propertyAccessor.getSetter( resultClass, alias );  
                    }  
                }  
            }  
            //实例实体对像  
            result = resultClass.newInstance();  
  
            for ( int i = 0; i < aliases.length; i++ ) {  
                if ( setters[i] != null ) {  
                    //向setter方法中指定的属性注入值  
                    setters[i].set( result, tuple[i], null );  
                }  
            }  
        }  
        catch ( InstantiationException e ) {  
            throw new HibernateException( "Could not instantiate resultclass: " + resultClass.getName() );  
        }  
        catch ( IllegalAccessException e ) {  
            throw new HibernateException( "Could not instantiate resultclass: " + resultClass.getName() );  
        }  
  
        return result;  
    } 

转自:http://gznofeng.iteye.com/blog/550705
分享到:
评论

相关推荐

    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