Hibernate Transformers之三種結果轉換說明


在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.  
  7. public Object transformTuple(Object[] tuple, String[] aliases) {   
  8.     Map result = new HashMap(tuple.length);   
  9.     for ( int i=0; i<tuple.length; i++ ) {   
  10.         String alias = aliases[i];   
  11.      if ( alias!=null ) {   
  12.          result.put( alias, tuple[i] );   
  13.      }   
  14.     } 
  15.  
  16.     return result;   
  17. }  

 

 

② 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(); 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM