Hibernate Transformers之三种结果转换说明

时间:2023-03-08 22:23:15

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

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

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

① ALIAS_TO_ENTITY_MAP :太简单了就是把key和value直接转换到Map当中 :

  1. /**
  2. * {@inheritDoc}
  3. */
  4. // aliases key
  5. // tuple value
  6. public Object transformTuple(Object[] tuple, String[] aliases) {
  7. Map result = new HashMap(tuple.length);
  8. for ( int i=0; i<tuple.length; i++ ) {
  9. String alias = aliases[i];
  10. if ( alias!=null ) {
  11. result.put( alias, tuple[i] );
  12. }
  13. }
  14. return result;
  15. }

Hibernate Transformers之三种结果转换说明

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

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

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

  1. getSession().beginTransaction();
  2. Query query = getSession().createSQLQuery("select * from operation");
  3. list =query.setResultTransformer(Transformers.aliasToBean(Operation.class)).list();
  4. getSession().getTransaction().commit();

Hibernate Transformers之三种结果转换说明