将原生SQL功能休眠到您的Spring Data Repository中

JPA为您提供@NamedNativeQuery以便使用本机SQL。 但是,用法不是很方便,尤其是当您需要在本机SQL中映射多个实体时。 您必须定义一组容易出错的SqlResultSetMapping映射。

对于以前使用过Hibernate本机SQL功能的用户,您会发现它比JPA的@NamedNativeQuery更易于使用。 在最近的项目中,我正在使用Spring Data JPA。 我已将休眠的本机查询功能添加到我的Spring数据库中。 现在,您可以在JPA中执行本机查询,而无需使用SqlResultSetMapping。

1.添加您的客户注释@NativeQueries和@NativeQuery

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface NativeQueries {NativeQuery[] queries() default  {};
}
@Retention(RetentionPolicy.RUNTIME)
public @interface NativeQuery {String name()  default "";String sql()  default "";
}

2.在基本Spring Data Repository中添加方法“ queryNatively”。

如果您不知道如何向Spring数据JPA基础存储库添加自定义行为,请参阅我以前的文章, 了解如何自定义Spring数据JPA基础存储库 。 您可以在上一篇文章中看到,我有意在GenericRepositoryImpl中公开存储库接口(即springDataRepositoryInterface属性)。 这些小技巧使我可以轻松地访问存储库界面中的注释。

public List queryNatively(String nativeQueryName, LinkedHashMap<String,Class<?>> inEntityClasses, Map inParams ){SQLQuery query =  this.createHibernateNativeQuery( nativeQueryName,  inParams );//add entitiesif (inEntityClasses!=null) {      for (Object key: inEntityClasses.keySet()) {String entityClassAlias = key.toString();Class<?> entityClass = (Class<?>)inEntityClasses.get(key);  query.addEntity(entityClassAlias,entityClass);}    }//add parameterif (inParams != null){for (Object key: inParams.keySet()) {String queryParamName = key.toString();Object queryParamValue = inParams.get(key);query.setParameter(queryParamName, queryParamValue);}}  return (query!=null)? query.list() : null ;}private SQLQuery createHibernateNativeQuery (String nativeQueryName, Map inParams ){if (GenericRepository.class.isAssignableFrom(getSpringDataRepositoryInterface())) {Annotation nativeQueryAnn = getSpringDataRepositoryInterface().getAnnotation(NativeQueries.class);if(nativeQueryAnn != null){NativeQueries nativeQueries = (NativeQueries)nativeQueryAnn;NativeQuery[] queries  = nativeQueries.queries();for (NativeQuery sqlquery : queries) { if (StringUtils.equals(nativeQueryName, sqlquery.name())) {String sql  = sqlquery.sql();Session hiernateSess = em.unwrap(Session.class);SQLQuery query = hiernateSess.createSQLQuery(sql);//add parameterif (inParams != null){for (Object key: inParams.keySet()) {String queryParamName = key.toString();Object queryParamValue = inParams.get(key);query.setParameter(queryParamName, queryParamValue);}}  return query;}    }}}return null;}

3.示例用法

在存储库界面中,通过@NativeQueries和@NativeQuery批注定义要使用的本机SQL查询。 用法与调用休眠本机查询功能相似。 您可能只看到休眠别名和属性引用 。

@NativeQueries (queries = {@NativeQuery(name="query1", sql="SELECT {cat.*}, {mother.*}  FROM CATS c, CATS m WHERE c.MOTHER_ID = c.ID and c.name =  :catName "),@NativeQuery(name="query2", sql="SELECT {cat.*} FROM CATS where c.ID =  :catName")       }
)
public interface CatRepository extends GenericRepository<Cat, Long> {
}

在注入存储库的服务或业务类中,您只需简单地调用queryNatively()方法即可执行本机SQL查询。

@Service
public class CatService {@Injectprivate CatRepository catRepository;public List<Cat> searchCat( String catName) {List<Cat> catList;// Add entity mapping for your queryHashMap<String, Object> inParams = new HashMap<String, Object>();inParams.put("catName", "Felix");// Prepare parameters for your native sqlLinkedHashMap<String, Object> entityMap = new LinkedHashMap<String, Object>();entityMap.put("cat", Cat.class);entityMap.put("mother",Mother.class);catList = catRepository.queryNatively("query1", "",entityParam);return catList;}
}

参考:来自Programming Peacely博客的JCG合作伙伴 Boris Lam 向您的Spring Data Repository中添加了Hibernate本机SQL功能 。


翻译自: https://www.javacodegeeks.com/2012/08/hibernate-native-sql-features-into-your.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/371606.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建yii的第一个应用

原文链接转载于:https://www.cnblogs.com/Baronboy/p/6354522.html

字符串匹配(KMP 算法 含代码)

主要是针对字符串的匹配算法进行解说 有关字符串的基本知识传统的串匹配法模式匹配的一种改进算法KMP算法网上一比較易懂的解说小样例1计算next 2计算nextval代码有关字符串的基本知识 串&#xff08;string或字符串&#xff09;是由零个或多个字符组成的有限序列&#xff0c;一…

php数组转为js json,javascript-将数组php转换为JSON时出错

我在将多维PHP数组转换为JSON时遇到了一些麻烦.我使用json_encode进行了转换,但它为null.我正在尝试开发orgChart,数据是从CSV文件中读取的,并保存在数组中.布局和JS代码用于接收JSON文件,因此我需要使用这种格式.这是数组的一部分,其中包含175个数组Array([2] > Array([id]…

UVa 10954 全部相加(Huffman编码)

https://vjudge.net/problem/UVA-10954 题意&#xff1a;有n个数的集合S&#xff0c;每次可以从S中删除两个数&#xff0c;然后把它们的和放回集合&#xff0c;直到剩下一个数。每次操作的开销等于删除的两个数之和&#xff0c;求最小开销。 思路&#xff1a;Huffman编码。 1 #…

serialVersionUID的作用以及如何用idea自动生成实体类的serialVersionUID

转载&#xff1a;http://blog.csdn.net/liuzongl2012/article/details/45168585 serialVersionUID的作用&#xff1a; 通过判断实体类的serialVersionUID来验证版本一致性的。在进行反序列化时&#xff0c;JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVer…

js post方式请求另外一个php,利用JS使用POST方式提交请求的方法(结合代码详细解答)...

下面是我给大家整理的利用JS使用POST方式提交请求的方法&#xff0c;有兴趣的同学可以去看看。一般都是写上隐藏的form标签&#xff0c;用来调用js函数然后submit全部用js来写也行&#xff0c;以下是我在一个问答频道看见别人写的例子&#xff0c;放在这里function post(URL, P…

JBoss BRMS最佳实践– BPM流程初始化层的提示

我过去发布过一些有关迁移策略的文章&#xff0c;仔细研究了流程层&#xff0c;并提供了一些有关jBPM的最佳实践 &#xff0c;它们都涉及到BPM策略的非常具体的部分。 我想重新讨论最佳实践的主题&#xff0c;然后在智能集成企业级别上&#xff0c;我们讨论使用JBoss BRMS对您的…

寒假作业二:汇总随笔

随笔一&#xff1a;解题思路随笔二&#xff1a;自学计划 转载于:https://www.cnblogs.com/mercuialC/p/6359997.html

跨站点脚本(XSS)和预防

如OWASP网站&#xff08;https://www.owasp.org/index.php/Cross-site_Scripting_(XSS&#xff09;&#xff09;所述&#xff0c;跨站点脚本&#xff08;XSS&#xff09;攻击的变种几乎是无限的。 在这里&#xff0c;我建议使用基于Servlet筛选器的解决方案来清理HTTP请求。 攻…

NoSQL入门第一天——NoSQL入门与基本概述

一、课程大纲 二、入门概述 1.为什么用NoSQL 单机MySQL的年代&#xff1a; 一个网站的访问量一般都不大&#xff0c;用单个数据库完全可以轻松应付。      我们来看看数据存储的瓶颈是什么&#xff1f;        1.数据量的总大小 一个机器放不下时。&#xff08;现…

随机森林特征个数mtry matlab,基于随机森林的特征选择算法

2.1 算法描述本文提出了一种基于随机森林的Wrapper特征选择方法RFFS,利用随机森林算法的变量重要性度量对特征进行排序,然后采用序列后向搜索方法,每次从特征集合中去掉一个最不重要(重要性得分最小)的特征,逐次进行迭代,并计算分类正确率,最终得到变量个数最少、分类正确率最高…

matlab循环读取变量,Matlab for 多个变量循环能不能这样啊 ,求教高手!!!!

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼for a0.003:0.0005:1; b0.002:0.0005:0.9; c0.001:0.0005:0.8;d0.0005:0.0005:0.7;E1a* E_Bone;E2b* E_Bone;E3c* E_Bone;E4d* E_Bone;G1a* G_Bone;G2b* G_Bone;G3c* G_Bone;G4d* G_Bone;%% Integration for cortical bone partsIn…

UVA - 10384 The Wall Pusher(推门游戏)(IDA*)

题意&#xff1a;从起点出发&#xff0c;可向东南西北4个方向走&#xff0c;如果前面没有墙则可走&#xff1b;如果前面只有一堵墙&#xff0c;则可将墙向前推一格&#xff0c;其余情况不可推动&#xff0c;且不能推动游戏区域边界上的墙。问走出迷宫的最少步数&#xff0c;输出…

JavaOne 2012:JavaOne技术主题演讲

Mark Reinhold从JavaOne 2012技术主题演讲开始。 他说&#xff0c;今年的版本将有所不同&#xff0c;因为它将使用大致相同的示例来说明Java的各个方面&#xff0c;而不是对Java的每个组件进行单独的单独介绍。 JavaFX团队的Richard Bair和Jasper Potts &#xff08;并与FXExpe…

C语言结构体及函数传递数组參数演示样例

C语言结构体及函数传递数组參数演示样例 注&#xff1a;makeSphere()函数返回Sphere结构体&#xff0c;main函数中。调用makeSphere()函数&#xff0c;传递的第一个參数为数组&#xff0c;传递的数组作为指针。posted on 2017-07-30 18:42 mthoutai 阅读(...) 评论(...) 编辑 收…

Maven内部版本号插件–用法示例

假设我们需要向一些工件&#xff08;jar&#xff0c;war等&#xff09;添加内部版本号。 在这里&#xff0c;我想演示buildnumber-maven-plugin的用法。 这篇文章基于&#xff1a; http://mojo.codehaus.org/buildnumber-maven-plugin/usage.html http://www.site.lalitbhatt…

Python魔法方法(magic method)细解几个常用魔法方法(下)

接上文&#xff0c;再介绍最后几个常用的魔法方法。 关于__dict__: 先上个例子&#xff1a; class Test(object):fly Truedef __init__(self, age):self.age age __dict__魔法方法可以被称为系统&#xff0c;他是存储各分层属性的魔法方法。__dict__中&#xff0c;键为属性名…

AIX下RAC搭建 Oracle10G(六)dbca建库

AIX下RAC搭建系列 AIX下RAC搭建 Oracle10G&#xff08;六&#xff09;dbca建库 环境 节点 节点1 节点2 小机型号 IBM P-series 630 IBM P-series 630 主机名 AIX203 AIX204 交换机 SAN光纤交换机 存储 SAN T3存储 大纲流程例如以下&#xff1a; 第一部分&#xff1…

php string slice,substring()与str.slice()区别

当接收的参数是负数时&#xff0c;slice会将它字符串的长度与对应的负数相加&#xff0c;结果作为参数&#xff1b;substr则仅仅是将第一个参数与字符串长度相加后的结果作为第一个参数&#xff1b;substring则干脆将负参数都直接转换为0。测试代码如下&#xff1a;var test h…

JavaOne 2012:掌握Java部署

在吃完一次JavaClass 2012午餐会的意大利经典组合后&#xff0c;我前往希尔顿帝国宴会厅B观看了演示“掌握Java部署”。 来自Oracle的发言人是Mark Howe和Igor Nekrestyano Howe表示&#xff0c;部署团队的目标是帮助Java开发人员将其应用程序部署到所选平台。 他首先讨论了“功…