掃二維碼與項目經理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流
你以前所參與的項目里面,SQL、HQL,是否滿天飛呢?在邏輯層,顯示層那里都可以看到隨手寫的Hibernate查詢語句?這樣的做法極度的破壞了分層的架構,無論如何的XP也應該遵循一定的管理與規(guī)范,那么統(tǒng)一管理查詢語句的重要性就凸現(xiàn)了。

成都創(chuàng)新互聯(lián)公司成立與2013年,先為雞東等服務建站,雞東等地企業(yè),進行企業(yè)商務咨詢服務。為雞東企業(yè)網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。
統(tǒng)一管理查詢語句有何優(yōu)點?
1、保持系統(tǒng)的分層架構,管理語句是持久層的責任,由它自己管理是最適合不過。松散的耦合總是我們向往的目標。
2、統(tǒng)一管理方便修改,可以減小人手修改帶來的低級錯誤。
OK,接下來要考慮如何管理這些語句來了。
1、配置文件管理
在Hibernate查詢語句的mapping文件內使用
Xml代碼
- from User eo where eo.id = ?
- from User eo where eo.id = ?
里面就是要使用的hql語句 屬性name就是語句保存在容器里的別名。 - 在hibernate的mapping文件內使用
- Xml代碼
- SELECT user.id AS {user.id},
- user.name AS {user.name}
- FROM t_user user WHERE user.name = ?
- SELECT user.id AS {user.id},
- user.name AS {user.name}
- FROM t_user user WHERE user.name = ?
寫好mapping文件后當然要告訴hibernate將這些語句加入到容器里面咯,配置方法有很多種,這里只列了使用spring結合hibernate的配置方式,在SessionFactoryBean的配置里面加入
Xml代碼
- classpath:hbm/name-query.hbm.xml
- classpath:hbm/name-query.hbm.xml
2、標簽管理
Hibernate查詢語句中,一般的習慣都是使用@NamedQueries將與自己相關的語句統(tǒng)一在實體里面,如查詢User的語句都是放到User對象里面
Java代碼
- @Entity
- @Table(name = "t_user")
- @Cache(usage = CacheConcurrencyStrategy.READ_WRITE) @NamedQueries( {
- @NamedQuery(name = "User.findById",
- query = "FROM User eo where eo.id=? ") })
- public class User implements java.io.Serializable {
- private int id;
- private String name;
- @Entity
- @Table(name = "t_user")
- @Cache(usage = CacheConcurrencyStrategy.READ_WRITE) @NamedQueries( {
- @NamedQuery(name = "User.findById",
- query = "FROM User eo where eo.id=? ") })
- public class User implements java.io.Serializable {
- private int id;
- private String name;
使用標簽管理可以比較好的分類Hibernate查詢語句,也不用搞麻煩的配置文件,雖然說修改配置文件的Hibernate查詢語句可以不用重新編譯就能生效,但是查詢語句修改也不會十分頻繁,所以標簽管理是一個不錯的選擇。

我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流