在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查询功能为我们提供了一种灵活的方式来执行复杂的数据库操作,同时通过`addEntity()`、`addScalar()`和`Transformers.aliasToBean()`等方法,我们可以方便地将查询结果封装成Java对象,...
- 如果查询结果中包含多张表的数据,可以使用`setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)`将结果转换为Map,键为列名,值为对应列的值。 通过理解并掌握以上内容,开发者可以有效地利用Hibernate将...
在本例中,使用了`addScalar`方法指定结果集中的列名及其对应的Java类型,并使用`setResultTransformer`设置结果转换器为`Transformers.aliasToBean(SumPlace.class)`。 ```java query1.addScalar("productSum", ...
另一种方式是使用`setResultTransformer()`,它可以自动将结果转换为我们想要的对象类型。这里我们可以使用`Transformers.aliasToBean(User.class)`: ```java query.setResultSetTransformer(Transformers....
查询结果通常是一个List,但我们可以使用Transformers类的实例化方法,如asList(), asScalar()等,来转换结果集。 10. **源码分析** 对于深入理解Criteria API的工作原理,查看和分析其源码是非常有价值的。通过...
还可以通过`Transformers`将查询结果转换为特定的对象,如`as(Class clazz)`可以将结果转换为指定类型的列表。 六、动态Criteria 动态Criteria允许我们在运行时构建查询,通过`createCriteria(String propertyName...
通过`setResultTransformer()`可以自定义结果转换,例如`Transformers.aliasToBean()`可以直接将查询结果转换为Java Bean。 9. **分页查询**:Criteria API同样支持分页查询,通过`setFirstResult()`和`...
- Projections和Criteria Transformers:用于查询结果的转换,如计算平均值、计数等。 7. **实体和持久化类** - 实体类:用注解@Entity标识,表示一个数据库表。 - 属性映射:@Id标识主键,@Column定义列属性,@...
12. **查询结果集转换**:Hibernate提供了`Transformers`类,可以将查询结果转换为自定义对象,方便数据处理。 13. ** Criteria API的子查询**:Criteria API支持创建子查询,可以嵌套在父查询中,实现复杂的数据...
- 使用Hibernate的Transformers工具类可以将结果转换为自定义类型。 8. **延迟加载和级联操作** - 延迟加载(Lazy Loading)允许只在需要时加载关联对象,提高性能。 - 级联操作(Cascade)可以在一个对象被操作...
8. **结果集转换(Transformers)**:可以将Criteria查询的结果转换为自定义的对象列表,如List、Map等。例如,将结果转换为Map列表: ```java List, Object>> result = criteria.setResultTransformer...
例如,`Transformers.aliasToBean(User.class)`将结果转换为User对象列表。 ```java criteria.setProjection(Projections.projectionList() .add(Projections.property("id")) .add(Projections.property("name")...
Hibernate Criteria API 是 Hibernate 框架中一个强大的查询工具,它提供了一种面向对象的方式来构建SQL查询,使得开发者无需直接编写SQL语句,即可进行复杂的数据库操作。Criteria API 提供了高度抽象的接口,可以...
Transformers.ALIAS_TO_ENTITY_MAP 是 Hibernate 中的一个转换器,用于将查询结果转换为 Map 对象。ALIAX_TO_ENTITY_MAP Transformer 将查询结果转换为 Map 对象,KEY 是数据库中的字段名,VALUE 是该字段的值。 ...
5. **自定义转换(Custom Transformers)**:Flexjson允许注册自定义的转换器,以便在序列化或反序列化过程中自定义特定类型的处理方式。 6. **动态模型(Dynamic Models)**:如果你不知道具体的数据结构,可以...
这段代码会执行`usp_GetEmployees`存储过程,并将结果转换为Employee对象的列表。 **处理输出参数和返回值** 如果存储过程有输出参数或返回值,我们需要在调用时显式处理。例如,一个存储过程可能有一个输入参数`@...
Hibernate的.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)。 因此,如果我们想要返回Map并且确定底层用的是某一种JPA的实现时,我们可以退而求其次,牺牲跨实现的特性来满足我们的需求: ```java ...