偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Hibernate查詢語(yǔ)句統(tǒng)一配置管理

開發(fā) 后端
本文向您介紹Hibernate查詢語(yǔ)句中統(tǒng)一配置管理的方法,包括配置文件的管理和標(biāo)簽管理等。

你以前所參與的項(xiàng)目里面,SQL、HQL,是否滿天飛呢?在邏輯層,顯示層那里都可以看到隨手寫的Hibernate查詢語(yǔ)句?這樣的做法極度的破壞了分層的架構(gòu),無(wú)論如何的XP也應(yīng)該遵循一定的管理與規(guī)范,那么統(tǒng)一管理查詢語(yǔ)句的重要性就凸現(xiàn)了。

統(tǒng)一管理查詢語(yǔ)句有何優(yōu)點(diǎn)?

1、保持系統(tǒng)的分層架構(gòu),管理語(yǔ)句是持久層的責(zé)任,由它自己管理是最適合不過(guò)。松散的耦合總是我們向往的目標(biāo)。

2、統(tǒng)一管理方便修改,可以減小人手修改帶來(lái)的低級(jí)錯(cuò)誤。

OK,接下來(lái)要考慮如何管理這些語(yǔ)句來(lái)了。

1、配置文件管理

在Hibernate查詢語(yǔ)句的mapping文件內(nèi)使用<query> 

Xml代碼

  1. <query name='findUserById'>      
  2.      from User eo where eo.id = ?      
  3. </query>   
  4.  
  5. <query name='findUserById'>   
  6.      from User eo where eo.id = ?   
  7. </query>      <query>里面就是要使用的hql語(yǔ)句 屬性name就是語(yǔ)句保存在容器里的別名。  
  8.  
  9.       
  10.  
  11.       在hibernate的mapping文件內(nèi)使用<sql-query>     
  12.  
  13. Xml代碼   
  14. <sql-query name="findUserByName">      
  15.      <return alias="user" class="hibernate.entity.User"/>      
  16.                SELECT user.id AS {user.id},      
  17.                             user.name AS {user.name}      
  18.                FROM t_user user WHERE user.name = ?      
  19. </sql-query>   
  20.  
  21. <sql-query name="findUserByName">   
  22.      <return alias="user" class="hibernate.entity.User"/>   
  23.                SELECT user.id AS {user.id},   
  24.                             user.name AS {user.name}   
  25.                FROM t_user user WHERE user.name = ?   
  26. </sql-query> 

<sql-query>里面的語(yǔ)句必須是sql語(yǔ)句,屬性name就是語(yǔ)句保存在容器里的別名,<reruen>里面的東東標(biāo)明了返回對(duì)象的類型與別名,別名主要用于對(duì)應(yīng)sql里面{}的內(nèi)容。

寫好mapping文件后當(dāng)然要告訴hibernate將這些語(yǔ)句加入到容器里面咯,配置方法有很多種,這里只列了使用spring結(jié)合hibernate的配置方式,在SessionFactoryBean的配置里面加入 

Xml代碼

  1. <property name="mappingLocations">      
  2.        <list>      
  3.            <value>      
  4.                 classpath:hbm/name-query.hbm.xml      
  5.            </value>      
  6.        </list>    
  7. </property>   
  8.  
  9. <property name="mappingLocations">   
  10.        <list>   
  11.            <value>   
  12.                 classpath:hbm/name-query.hbm.xml   
  13.            </value>   
  14.        </list> 
  15. </property> 

<sql-query>的使用比較復(fù)雜,所以不是遇到復(fù)雜的跨表查詢時(shí),不推薦使用。

2、標(biāo)簽管理

Hibernate查詢語(yǔ)句中,一般的習(xí)慣都是使用@NamedQueries將與自己相關(guān)的語(yǔ)句統(tǒng)一在實(shí)體里面,如查詢User的語(yǔ)句都是放到User對(duì)象里面

Java代碼

  1. @Entity    
  2. @Table(name = "t_user")      
  3. @Cache(usage = CacheConcurrencyStrategy.READ_WRITE) @NamedQueries( {      
  4.        @NamedQuery(name = "User.findById",      
  5.                query = "FROM User eo where eo.id=? ") })      
  6. public class User implements java.io.Serializable {      
  7.                      
  8.                 private int id;      
  9.               
  10.                 private String name;   
  11.  
  12. @Entity 
  13. @Table(name = "t_user")   
  14. @Cache(usage = CacheConcurrencyStrategy.READ_WRITE) @NamedQueries( {   
  15.        @NamedQuery(name = "User.findById",   
  16.                query = "FROM User eo where eo.id=? ") })   
  17. public class User implements java.io.Serializable {   
  18.                   
  19.                 private int id;   
  20.            
  21.                 private String name; 

使用標(biāo)簽管理可以比較好的分類Hibernate查詢語(yǔ)句,也不用搞麻煩的配置文件,雖然說(shuō)修改配置文件的Hibernate查詢語(yǔ)句可以不用重新編譯就能生效,但是查詢語(yǔ)句修改也不會(huì)十分頻繁,所以標(biāo)簽管理是一個(gè)不錯(cuò)的選擇。

 

【編輯推薦】

  1. Hibernate優(yōu)化查詢功能
  2. Hibernate2和Hibernate3連接池配置
  3. Hibernate 連接池的配置方式
  4. 關(guān)于Hibernate級(jí)聯(lián)刪除的問(wèn)題
  5. Hibernate 刪除出現(xiàn)異常的解決方案
責(zé)任編輯:佚名 來(lái)源: JavaEye
相關(guān)推薦

2009-09-24 10:35:10

Hibernate查詢

2022-09-09 10:00:13

KubernetesConfigMap

2023-04-10 08:11:27

Jenkins數(shù)據(jù)庫(kù)

2021-08-09 06:57:42

客戶端流程配置

2010-12-21 18:07:39

2021-09-08 15:09:29

鴻蒙HarmonyOS應(yīng)用

2010-01-08 10:18:47

Ubuntu MySQ

2022-05-06 12:04:24

Ansible管理工具

2023-05-30 07:50:56

項(xiàng)目管理權(quán)限

2009-09-24 10:15:37

Hibernate查詢

2011-02-25 14:00:15

ProFTPD

2011-11-23 13:29:05

2009-03-03 17:17:52

環(huán)境配置軟件開發(fā)

2023-04-27 08:18:25

GitLab開源

2013-10-22 09:37:14

網(wǎng)絡(luò)配置管理網(wǎng)絡(luò)性能監(jiān)控

2009-03-25 09:52:00

虛擬網(wǎng)絡(luò)VLAN配置

2011-05-17 14:25:44

虛擬化安全VMwareShavlik

2021-03-27 10:51:21

SaaS安全配置管理SSPM)攻擊

2022-07-07 10:43:58

安全配置管理SCM

2009-07-02 09:23:27

Hibernate緩存
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)