Hibernate查询语句统一配置管理

开发 后端
本文向您介绍Hibernate查询语句中统一配置管理的方法,包括配置文件的管理和标签管理等。

你以前所参与的项目里面,SQL、HQL,是否满天飞呢?在逻辑层,显示层那里都可以看到随手写的Hibernate查询语句?这样的做法极度的破坏了分层的架构,无论如何的XP也应该遵循一定的管理与规范,那么统一管理查询语句的重要性就凸现了。

统一管理查询语句有何优点?

1、保持系统的分层架构,管理语句是持久层的责任,由它自己管理是最适合不过。松散的耦合总是我们向往的目标。

2、统一管理方便修改,可以减小人手修改带来的低级错误。

OK,接下来要考虑如何管理这些语句来了。

1、配置文件管理

在Hibernate查询语句的mapping文件内使用<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语句 属性name就是语句保存在容器里的别名。  
  8.  
  9.       
  10.  
  11.       在hibernate的mapping文件内使用<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>里面的语句必须是sql语句,属性name就是语句保存在容器里的别名,<reruen>里面的东东标明了返回对象的类型与别名,别名主要用于对应sql里面{}的内容。

写好mapping文件后当然要告诉hibernate将这些语句加入到容器里面咯,配置方法有很多种,这里只列了使用spring结合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>的使用比较复杂,所以不是遇到复杂的跨表查询时,不推荐使用。

2、标签管理

Hibernate查询语句中,一般的习惯都是使用@NamedQueries将与自己相关的语句统一在实体里面,如查询User的语句都是放到User对象里面

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; 

使用标签管理可以比较好的分类Hibernate查询语句,也不用搞麻烦的配置文件,虽然说修改配置文件的Hibernate查询语句可以不用重新编译就能生效,但是查询语句修改也不会十分频繁,所以标签管理是一个不错的选择。

 

【编辑推荐】

  1. Hibernate优化查询功能
  2. Hibernate2和Hibernate3连接池配置
  3. Hibernate 连接池的配置方式
  4. 关于Hibernate级联删除的问题
  5. Hibernate 删除出现异常的解决方案
责任编辑:佚名 来源: JavaEye
相关推荐

2009-09-24 10:35:10

Hibernate查询

2022-09-09 10:00:13

KubernetesConfigMap

2023-04-10 08:11:27

Jenkins数据库

2021-08-09 06:57:42

客户端流程配置

2010-12-21 18:07:39

2021-09-08 15:09:29

鸿蒙HarmonyOS应用

2010-01-08 10:18:47

Ubuntu MySQ

2022-05-06 12:04:24

Ansible管理工具

2023-05-30 07:50:56

项目管理权限

2009-09-24 10:15:37

Hibernate查询

2011-11-23 13:29:05

2011-02-25 14:00:15

ProFTPD

2009-03-03 17:17:52

环境配置软件开发

2023-04-27 08:18:25

GitLab开源

2021-03-27 10:51:21

SaaS安全配置管理SSPM)攻击

2011-05-17 14:25:44

虚拟化安全VMwareShavlik

2013-10-22 09:37:14

网络配置管理网络性能监控

2022-07-07 10:43:58

安全配置管理SCM

2009-03-25 09:52:00

虚拟网络VLAN配置

2022-09-08 09:00:38

Ansible开源
点赞
收藏

51CTO技术栈公众号