HibernateTemplate类的使用

2024-01-15 01:58
文章标签 使用 hibernatetemplate

本文主要是介绍HibernateTemplate类的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1.  /**   
  2. * 向数据库添加一条对应于一个业务对象实例的记录   
  3.  
  4. * @param entity   
  5. * 业务对象实例   
  6.       */    
  7. public Entity create(Entity entity) throws DaoException {    
  8. try {    
  9. getHibernateTemplate().save(entity);    
  10. return entity;    
  11. catch (DataAccessException e) {    
  12.             throw new DaoException("保存 " + entity.getClass().getName()    
  13. " 实例到数据库失败", e);    
  14. }    
  15. }    
  16.   
  17. /**   
  18. * 向数据库更新一条对应于一个业务对象实例的记录   
  19.  
  20. * @param entity   
  21.       * 业务对象实例   
  22.       */    
  23. public void update(Entity entity) throws DaoException {    
  24. try {    
  25. getHibernateTemplate().update(entity);    
  26. catch (DataAccessException e) {    
  27.             throw new DaoException("更新 " + entity.getClass().getName()    
  28. " 实例到数据库失败", e);    
  29. }    
  30. }    
  31.   
  32. /**   
  33. * 从数据库删除一条对应于一个业务对象的记录   
  34.  
  35. * @param entity   
  36. * 业务对象实例   
  37.       */    
  38. public void delete(Entity entity) throws DaoException {    
  39. try {    
  40. getHibernateTemplate().delete(entity);    
  41. catch (DataAccessException e) {    
  42.             throw new DaoException("从数据库删除 " + entity.getClass().getName()    
  43. " 实例失败", e);    
  44. }    
  45. }    
  46.   
  47. /**   
  48. * 从数据库删除所有对应于一个业务对象的记录   
  49.  
  50. * @param clazz   
  51. * 指定类型的业务对象   
  52.       */    
  53. public void deleteAll(Class clazz) throws DaoException {    
  54. try {    
  55. List result = getHibernateTemplate().loadAll(clazz);    
  56. getHibernateTemplate().deleteAll(result);    
  57. catch (DataAccessException e) {    
  58. log.error("从数据库删除 " + clazz.getName() + " 的所有记录失败", e);    
  59. throw new DaoException("从数据库删除 " + clazz.getName() + " 的所有记录失败", e);    
  60. }    
  61. }    
  62.   
  63. public void deleteAll(Collection entities) throws DaoException {    
  64. try {    
  65. getHibernateTemplate().deleteAll(entities);    
  66. catch(DataAccessException e) {    
  67. throw new DaoException(e);    
  68. }    
  69. }    
  70.   
  71. /**   
  72. * 根据关键字从数据库加载指定类型的业务对象。   
  73.  
  74. * @param clazz   
  75. * 业务对象的Class   
  76. * @param keyName   
  77. * 指定关键字对应的字段名称   
  78. * @param keyValue   
  79. * 指定关键字的值   
  80. * @return <ul>   
  81. * <li>当关键字唯一并存在该记录时,返回该记录对应的业务对象</li>  
  82. * <li>当关键字不唯一,返回查询结果的第一条记录所对应的业务对象</li>  
  83. * <li>当不存在该记录时,返回null</li>   
  84.       */    
  85. public Object loadByKey(Class clazz, String keyName, Object keyValue)    
  86. throws DaoException {    
  87. try {    
  88. List result = getHibernateTemplate().find(    
  89. "from " + clazz.getName() + " where " + keyName + " = ?",    
  90. keyValue);    
  91. if (result != null && result.size() > 0) {    
  92. return result.get(0);    
  93. else {    
  94. return null;    
  95. }    
  96. catch (DataAccessException e) {    
  97.             throw new DaoException("加载 " + keyName + " 为 " + keyValue + " 的 "    
  98. + clazz.getName() + " 实例失败", e);    
  99. }    
  100. }    
  101.   
  102. /**   
  103. * 从数据库加载指定类型的业务对象的所有记录。   
  104.  
  105. * @param clazz   
  106. * 业务对象的Class   
  107. * @return 返回数据库中对应该业务对象的所有记录的集合   
  108.       */    
  109. public List loadAll(Class clazz) throws DaoException {    
  110. try {    
  111. return getHibernateTemplate().loadAll(clazz);    
  112. catch (DataAccessException e) {    
  113.             throw new DaoException("加载所有 " + clazz.getName() + " 实例时失败", e);    
  114. }    
  115. }    
  116.   
  117. /**   
  118. * 根据查询语句查询数据库并返回查询结果所包含的业务对象集合。   
  119.  
  120. * @param queryString   
  121. * 指定查询语句   
  122. * @return 返回查询结果包含的业务对象集合   
  123.       */    
  124. public List find(String queryString) throws DaoException {    
  125. try {    
  126. return getHibernateTemplate().find(queryString);    
  127. catch (DataAccessException e) {    
  128.             throw new DaoException("执行查询 " + queryString + " 失败", e);    
  129. }    
  130. }    
  131.   
  132. /**   
  133. * 根据带一个参数的查询语句查询数据库并返回查询结果所包含的业务对象集合。  
  134.  
  135. * @param queryString   
  136. * 指定查询语句   
  137. * @param param   
  138. * 指定所带参数   
  139. * @return 返回查询结果包含的业务对象集合   
  140.       */    
  141. public List find(String queryString, Object param) throws DaoException {    
  142. try {    
  143. return getHibernateTemplate().find(queryString, param);    
  144. catch (DataAccessException e) {    
  145.             throw new DaoException("执行参数为 " + param + " 的查询 " + queryString    
  146. " 失败", e);    
  147. }    
  148. }    
  149.   
  150. /**   
  151. * 根据带多个参数的查询语句查询数据库并返回查询结果所包含的业务对象集合。  
  152.  
  153. * @param queryString   
  154. * 指定查询语句   
  155. * @param params   
  156. * 指定参数数组   
  157. * @return 返回查询结果包含的业务对象集合   
  158.       */    
  159. public List find(String queryString, Object[] params) throws DaoException {    
  160. try {    
  161. return getHibernateTemplate().find(queryString, params);    
  162. catch (DataAccessException e) {    
  163. StringBuffer paramString = new StringBuffer("");    
  164. for (int i = 0; i < params.length; i++) {    
  165. paramString.append(params[i]);    
  166. paramString.append(" ");    
  167. }    
  168.             throw new DaoException("执行参数为 " + paramString + "的查询 "    
  169. + queryString + " 失败", e);    
  170. }    
  171. }    
  172.   
  173. /**   
  174. * 根据已定义的查询语句查询数据库并返回查询结果所包含的业务对象集合。   
  175.  
  176. * @param queryName   
  177. * 已定义查询语句的名称   
  178. * @return 返回查询结果包含的业务对象集合   
  179.       */    
  180. public List findByNamedQuery(String queryName) throws DaoException {    
  181. try {    
  182. return getHibernateTemplate().findByNamedQuery(queryName);    
  183. catch (DataAccessException e) {    
  184.             throw new DaoException("执行命名为 " + queryName + " 的查询失败");    
  185. }    
  186. }    
  187.   
  188. /**   
  189. * 根据已定义的带一个参数的查询语句查询数据库并返回查询结果所包含的业务对象集合。  
  190.  
  191. * @param queryName   
  192. * 已定义查询语句的名称   
  193. * @param param   
  194. * 指定的参数   
  195. * @return 返回查询结果包含的业务对象集合   
  196.       */    
  197. public List findByNamedQuery(String queryName, Object param)    
  198. throws DaoException {    
  199. try {    
  200. return getHibernateTemplate().findByNamedQuery(queryName, param);    
  201. catch (DataAccessException e) {    
  202.             throw new DaoException("执行参数为 " + param + " 命名为 " + queryName    
  203. " 的查询失败");    
  204. }    
  205. }    
  206.   
  207. /**   
  208. * 根据已定义的带多个参数的查询语句查询数据库并返回查询结果所包含的业务对象集合。  
  209.  
  210. * @param queryName   
  211. * 已定义查询语句的名称   
  212. * @param params   
  213. * 指定的参数数组   
  214. * @return 返回查询结果包含的业务对象集合   
  215.       */    
  216. public List findByNameQuery(String queryName, Object[] params)    
  217. throws DaoException {    
  218. try {    
  219. return getHibernateTemplate().findByNamedQuery(queryName, params);    
  220. catch (DataAccessException e) {    
  221. StringBuffer paramString = new StringBuffer("");    
  222. for (int i = 0; i < params.length; i++) {    
  223. paramString.append(params[i]);    
  224. paramString.append(" ");    
  225. }    
  226.             throw new DaoException("执行参数为 " + paramString + "命名为 " + queryName    
  227. " 的查询失败");    
  228. }    
  229. }  

HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作, Spring 2.0更增加对命名 SQL 查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate 的常规用法,就可完成大多数 DAO 对象的 CRUD 操作。下面是 HibernateTemplate 的常用方法简介:

q     void delete(Object entity) :删除指定持久化实例

q     deleteAll(Collection entities) :删除集合内全部持久化类实例

q     find(String queryString) :根据HQL 查询字符串来返回实例集合

q     findByNamedQuery(String queryName) :根据命名查询返回实例集合

q     get(Class entityClass, Serializable id) :根据主键加载特定持久化类的实例

q     save(Object entity) :保存新的实例

q     saveOrUpdate(Object entity) :根据实例状态,选择保存或者更新

q     update(Object entity) :更新实例的状态,要求entity 是持久状态

q     setMaxResults(int maxResults) :设置分页的大小

这篇关于HibernateTemplate类的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607276

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV