java jinq_将JINQ与JPA和H2一起使用

java jinq

几天前,我读了Iu Ming-Yee对JINQ的有趣采访 。 顾名思义,JINQ是一种尝试提供类似于LINQ for Java的尝试。 基本思想是缩小在关系数据模型上执行查询的面向对象代码之间的语义鸿沟。 关系数据库模型的查询应轻松集成到代码中,以使其感觉更自然。

LINQ背后的研究得出的结论是,将代码转换为关系数据库查询的算法最适合功能代码。 当Java 8附带流API时,作者使用它来实现Java博士学位的想法。

为了弄清我们的手,我们从一个简单的项目开始,该项目使用Hibernate over JPA以及H2数据库和JINQ:

<dependencies><dependency><groupId>javax</groupId><artifactId>javaee-api</artifactId><version>${jee.version}</version><scope>provided</scope></dependency><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><version>${h2.version}</version></dependency><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-entitymanager</artifactId><version>${hibernate.version}</version></dependency><dependency><groupId>org.jinq</groupId><artifactId>jinq-jpa</artifactId><version>1.8.10</version></dependency>
</dependencies>

为了使用JINQ流,我们必须创建一个将EntityManagerFactory作为参数的提供程序:

EntityManagerFactory factory = Persistence.createEntityManagerFactory("PersistenceUnit");
JinqJPAStreamProvider streams = new JinqJPAStreamProvider(factory);

将一些人插入我们的数据库后,我们可以轻松地查询他们:

List<String> firstNames = streams.streamAll(entityManager, Person.class).map(Person::getFirstName).collect(toList());
firstNames.forEach(System.out::println);

使用先前创建的JinqJPAStreamProvider streamAll()方法,我们可以访问数据库中的所有人员。 在这个简单的例子中,我们只想输出每个人的名字; 因此,我们map列表并将所有结果collectList 。 使用forEach()方法和对println()方法的引用来打印此列表。

看一下生成SQL代码,我们看到选择了所有列:

selectperson0_.id as id1_4_,person0_.FIRST_NAME as FIRST_NA2_4_,person0_.ID_CARD_ID as ID_CARD_4_4_,person0_.LAST_NAME as LAST_NAM3_4_,
fromT_PERSON person0_

当然,我们可以使用select()方法来优化语句:

List<String> firstNames = streams.streamAll(entityManager, Person.class).select(Person::getFirstName).where(p -> p.equals("Homer")).collect(toList());
firstNames.forEach(System.out::println);

此外,我们还添加了一个谓词( where firstName = 'Homer' ):

selectperson0_.FIRST_NAME as FIRST_NA2_4_
fromT_PERSON person0_ 
whereperson0_.FIRST_NAME='Homer'

留下这个简单的示例,我们现在要创建一个查询,以选择在时间和物质项目中工作的所有具有“ Christian”名字的怪胎:

List<String> geeks = streams.streamAll(entityManager, Project.class).where(p -> p.getProjectType() == Project.ProjectType.TIME_AND_MATERIAL).joinList(Project::getGeeks).where(g -> g.getTwo().getFirstName().equals("Christian")).map(p -> p.getTwo().getFirstName()).collect(toList());
geeks.forEach(System.out::println);

从上面的代码可以看出,我们使用第一个where()子句选择所有时间和材料项目。 joinList()调用连接了怪胎表,而随后的where()子句还限制为仅选择名字为“ Christian”的怪胎。 等等,这就是创建SQL查询:

selectgeek2_.FIRST_NAME as col_0_0_ 
fromT_PROJECT project0_ 
inner joinT_GEEK_PROJECT geeks1_ on project0_.id=geeks1_.PROJECT_ID 
inner joinT_GEEK geek2_ on geeks1_.GEEK_ID=geek2_.id 
whereproject0_.projectType='TIME_AND_MATERIAL'and geek2_.FIRST_NAME='Christian' limit ?

结束语 :前一段时间使用JPA的标准API,我必须说,使用JINQ的第一步更直观,更容易写下来。 通过使用Java 8中的流,JINQ确实有助于缩小关系数据库世界之间的差距。

翻译自: https://www.javacodegeeks.com/2016/04/using-jinq-jpa-h2.html

java jinq

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

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

相关文章

HTML设置字体颜色1008无标题,如何在HTML中设置字体颜色,你知道这几种方式吗?...

color设置字体颜色在color设置字体颜色之前&#xff0c;我们首先了解color在css中有几种取值方式&#xff0c;一共有4种方式&#xff0c;若有不全还请在评论区告知谢谢&#xff0c;4种方式如下&#xff1a;十六进制、十进制、 英文单词、十六进制的缩写。现在让我们进入字体颜色…

gram矩阵_Skip-gram

Skip-gram标签(空格分隔)&#xff1a;NLP一. skip-gram和cbow的对比 skip-gram与cbow相比&#xff0c;好处在于对于不常用的词&#xff0c;skip-gram的效果要更好&#xff1b;举个简单的例子&#xff0c;一个句子w1w2w3w4&#xff0c;window_size1&#xff1b;对于cbow&#xf…

html dom的nodetype值介绍,HTML DOM nodeType 属性

HTML DOM nodeType 属性实例获得 body 元素的节点类型&#xff1a;document.body.nodeType;结果&#xff1a;1定义和用法nodeType 属性返回以数字值返回指定节点的节点类型。如果节点是元素节点&#xff0c;则 nodeType 属性将返回 1。如果节点是属性节点&#xff0c;则 nodeTy…

应行家算法_一些行家技巧和窍门

应行家算法我正在将使用WebLogic Workshop&#xff08;是的&#xff0c;使用不受支持的IDE可以正确阅读&#xff09;的现有应用程序迁移到Maven。 在旅途中有一些陷阱&#xff0c;我想在这里写下给那些可能会觉得有用的人&#xff0c;特别是对我自己而言作为参考。 整个应用程…

C++ 11 深度学习(十五)多线程

线程创建 方式一:调用函数 #include<thread>void CreateThread() {int a100;cout<<"This is Thread: "<<a<<endl; }int main() {thread Threadone(CreateThread);//join是一种阻塞的方式&#xff0c;需要子线程处理完毕之后&#xff0c;…

pythonfor循环语句例题_python循环语句的使用练习题

1. 使用while循环输出1 2 3 4 5 6 8 9 10 for i in range(10) : if i6 : print( ,end ) continue print(i1,end" ") 2. 求1-100的所有数的和 s0 for i in range(101) : si print(s) 3. 输出 1-100 内的所有奇数 for i in range(100) : if (i1)%21 : print(i1,end ) 4…

计算机的好处和坏处的英语作文,电脑的利弊英语作文

电脑的利弊英语作文在学习、工作或生活中&#xff0c;大家都写过作文吧&#xff0c;通过作文可以把我们那些零零散散的思想&#xff0c;聚集在一块。那么你有了解过作文吗&#xff1f;下面是小编为大家整理的电脑的利弊英语作文&#xff0c;希望能够帮助到大家。Computer is in…

多个定时器相互干扰的问题_相互问题

多个定时器相互干扰的问题HTTPS协议是建立安全连接的公认标准。 理解此协议的工作原理不是问题&#xff0c;并且自2000年以来可以使用相应的RFC文档 。 尽管HTTPS的使用如此广泛&#xff0c;但您仍然可以找到没有不必要的复杂性就无法处理此协议的软件。 不幸的是&#xff0c;…

【WebRTC---进阶篇】(一)服务器基础编程

一个最简单的服务器程序 server.h /*** Server Class ** @author lichao* @date 2019-08-07* @copyleft GPL 2.0*/#ifndef __SERVER_H__ #define __SERVER_H__namespace avdance {class Server {public:Server(); //consrtuct~Server(); //destructpublic:void run();};} //…

servlet容器_SpringBoot是否内置了Servlet容器?

SpringBoot是否内置了Servlet容器&#xff1f;SpringBoot内置了Servlet容器&#xff0c;这样项目的发布、部署就不需要额外的Servlet容器&#xff0c;直接启动jar包即可。SpringBoot官方文档上有一个小章节内置servlet容器支持用于说明内置Servlet的相关问题。在SpringBoot源码…

计算机专业开学要带电脑吗,大学上课要带电脑吗

大学刚开学&#xff0c;上课的时候学生们要不要带电脑呢&#xff0c;想必这个问题一直对还没进入大学的准大学生来说很困扰&#xff0c;下面是小编整理的详细内容&#xff0c;一起来看看吧&#xff01;大学上课要带电脑吗大学上课能否带电脑需要看老师的要求。大学课程书本知识…

【WebRTC---进阶篇】(二)libevent实现高性能网络服务器

libevent编译与安装 libevent官网 Linux平台安装编译libevent wget -c addr --no-check-certificate ./configure --prefix=/usr/local/libevent make -j 8 make install #include <event2/listener.h> #include <event2/bufferevent.h> #include <event2/b…

突然讨厌做前端,讨厌代码_不要讨厌HATEOAS

突然讨厌做前端,讨厌代码或我如何学会不再担心和爱HATEOAS REST已成为实现Web服务的事实上的解决方案&#xff0c;至少已成为一种流行的解决方案。 这是可以理解的&#xff0c;因为REST在使用HTTP规范时提供了一定程度的自我文档。 它经久耐用&#xff0c;可扩展&#xff0c;并…

html按钮冻结,Vue js按钮冻结dom

我想切换一个包含加载动画的按钮按钮&#xff0c;直到该函数完成使用v-if。但是当我按下按钮时&#xff0c;DOM冻结&#xff0c;span元素不变&#xff0c;直到函数调用结束。我如何让DOM不冻结并显示加载图标&#xff1f;非阻塞按钮按下可能是一个解决方案&#xff1f;Vue js按…

【WebRTC---进阶篇】(三)各流媒体服务器的比较

多人音视频架构 Mesh方案 多对多大多进行P2P,在国内P2P直连穿越会出现很大问题。 MCU方案 客户端连接后,对应每个终端都有一个模块进项上传。再将音视频进行拆分解码。进行混屏,压缩编码分别推动给每个终端。 SFU方案 sfu不进行编解码,只是进行转发。只对订阅的终端进行…

注释嵌套注释_DIY注释

注释嵌套注释从Java 5开始&#xff0c;Java中出现了注释。 我想做一个自己的注释&#xff0c;只是为了看看需要什么。 但是&#xff0c;我发现它们只是接口。 有擦 接口后面没有牙。 必须执行一些代码。 我认为这是橡胶行之有效的方法&#xff0c;我真的找到了解决方法。 首先…

汇编 cmp_汇编复习

第一章计算机组成五部分&#xff1a;&#xff08;运算器、控制器&#xff09;、存储器、输入/输出设备↑↑ CPU ↑↑ ↑内存↑三条总线&#xff1a;控制总线、地址总线、数据总线不同进制及BCD码的转换特殊ascll ‘0’~‘9’—— 30H ~ 39H‘A’~‘F’—— 41H ~ 46H回车 —— …

【WebRTC---进阶篇】(四)mediasoup服务器的布署与使用

Nodejs安装 Nodejs安装 下载mediasoup Demo,并配置 详细GitHub地址 https://github.com/versatica/mediasoup-demo

睡眠是锁定计算机怎么设置密码,电脑休眠锁屏怎么设置

想要保护好自己的隐私&#xff0c;就要懂得电脑休眠锁屏怎么设置哦&#xff01;什么&#xff1f;你不会设置&#xff1f;不怕&#xff0c;小编这就来为您支招&#xff01;请看下文内容&#xff01;电脑休眠锁屏怎么设置用户账户面板1、首先您需要创建用户密码&#xff0c;如果您…

junit5和junit4_JUnit 5 –设置

junit5和junit42015年11月&#xff0c; JUnit Lambda团队展示了他们的原型 。 此后&#xff0c;该项目更名为JUnit 5&#xff0c;并于2016年2月发布了Alpha版本。我们将在一系列简短文章中进行探讨&#xff1a; 建立 基本 建筑 条件 注射 … 本节讨论JUnit 5的设置&…