jooq sql_jOOQ星期二:Vlad Mihalcea深入了解SQL和Hibernate

jooq sql

欢迎来到jOOQ Tuesdays系列。 在本系列文章中,我们每隔一个月的第三个星期二发布一篇文章,从jOOQ的角度采访我们发现该行业令人兴奋的人。 这包括从事SQL,Java,开放源代码以及各种其他相关主题的人员。 vlad_mihalcea

我们很高兴在第三版中与Vlad Mihalcea交谈,他将向我们介绍开发人员在使用Java,SQL和Hibernate时需要掌握的技能。

嗨,弗拉德(Vlad)-您的博客爆满了有关Hibernate的精彩文章。 看起来您喜欢深入研究市场上最流行的持久性API,对吗?

我的意思是说“教学是我的学习方式”并掌握某种技术时,您必须超越参考文档。 Hibernate已经存在了十年,并且在其之上构建了许多项目。 Hibernate大师班侧重于一些经过验证的ORM设计模式,例如并发控制,缓存和批处理。

您最近告诉我您已经意识到我们行业中缺乏SQL洞察力。 怎么会这样?

在访问数据时,对象关系不匹配只是冰山一角。 我们在企业系统中面临的最大问题是企业数据库开发人员不匹配。

开发人员了解编程语言,设计模式和应用程序架构,但是数据库技能始终归因于数据库管理员角色。 这是一个非常危险的假设。

好像我们是在Linux上进行开发,而又不想完全依靠系统管理员的知识来学习操作系统的工作方式一样。 如果您开发企业应用程序,那么您除了学习数据库的工作原理之外,别无选择。 阅读出色的《 SQL Performance Explained 》一书,使我意识到对关系数据库系统的内部工作了解甚少。 本书仅供开发人员使用,是每位企业开发人员的必备读物。

我们该如何改善行业状况? 是否有可能将JPA与SQL紧密集成? 还是具体地说,是Hibernate和jOOQ?

首先,这是需要改变的心态。 我们需要承认,没有一种“一刀切”的框架,它也适用于数据库访问。 当我编写单元测试时,我并不局限于JUnit。 我还使用了Mockito和Hamcrest,这是一个更好的选择。

JPA在写入数据时表现出色,因为只要持久性模型发生更改,您就可以自动更新INSERT / UPDATE语句。 隐式和显式锁定使我们能够防止丢失更新,尤其是在长时间对话的工作流中。

但是,尽管抽象SQL写语句是一个可行的任务,但是在读取数据时,没有什么能比原生SQL强。 最常用的RDBMS已经实现了非标准的数据访问技术(窗口函数,公共表表达式,PIVOT),而SQL-92 JPA抽象层只能专注于公共功能。 这就是为什么在几乎所有企业系统上都不可避免地进行本地查询的原因。

jOOQ在将SQL知识推广到Java生态系统方面做得非常出色。 Java统治着企业软件开发,而SQL技能一直是大多数企业开发团队的致命弱点。

虽然您可以从JPA触发本机查询,但不支持动态本机查询构建。 jOOQ允许您构建类型安全的动态本机查询,从而增强应用程序抵抗SQL注入攻击。 正如我在博客中已经证明的那样,jOOQ可以与JPA集成,并且JPA-jOOQ组合可以提供可靠的数据访问堆栈。

告诉我们一些有关您的Hibernate Master Class和您个人博客策略的信息。

Hibernate Master Class博客系列实际上是一本正在编写的书。 因为我从事全职工作,所以很难按照固定的写作时间表进行写作,所以我只能在业余时间允许的范围内写作。

涵盖了所有主题之后,我将按照“ SQL Performance Explained”示例将所有这些信息转变成一本书,由我自行出版。

五年后你会在哪里?

我既喜欢软件体系结构,也喜欢写作。 我将继续这一旅程,看看风将把我带到哪里。

翻译自: https://www.javacodegeeks.com/2015/04/jooq-tuesdays-vlad-mihalcea-gives-deep-insight-into-sql-and-hibernate.html

jooq sql

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

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

相关文章

C语言灵魂拷问:++i 为比 i++效率高?

点击蓝字关注我们相信很多人遇到过这样的问题:printf("%d,%d",i,i);也纠结过这个问题,到底答案是什么。确没有一个参考的资料。唯一知道的是,几乎所有C语言教材都这么讲:i就是先使用i的值再使i自身加一,而i则…

HibernateNONSTRICT_READ_WRITE CacheConcurrencyStrategy如何工作

介绍 在我以前的文章中 ,我介绍了READ_ONLY CacheConcurrencyStrategy ,这是不可变实体图的显而易见的选择。 当高速缓存的数据可变时,我们需要使用读写高速缓存策略,本文将介绍NONSTRICT_READ_WRITE二级高速缓存的工作方式。 内…

502无法解析服务器标头_编写下载服务器。 第三部分:标头:内容长度和范围...

502无法解析服务器标头这次,我们将探索更多HTTP请求和响应标头,以改善下载服务器的实现: Content-length和Range 。 前者表示下载量很大,后者允许部分下载文件,或者从我们开始的地方失败后继续下载。 Content-length响…

支付宝pc支付php,laravel框架下的pc支付宝支付接入

Time: 14:22*/return [//pc配置pcconfig>[partner >2088302186611, //这里是你在成功申请支付宝接口后获取到的PID;key >sxevk9h1vekjlx4y12arl6pryrz111, //这里是你在成功申请支付宝接口后获取到的Keyseller_id >208830211, //就是partnersign_type &…

最全,面中率最高的C++经典面试题分享!

点击蓝字关注我们1.new、delete、malloc、free关系delete会调用对象的析构函数,和new对应free只会释放内存,new调用构造函数。malloc与free是C/C语言的标准库函数,new/delete是C的运算符。它们都可用于申请动态内存和释放内存。对于非内部数据类型的对象…

mysql不同版本会覆盖吗,[mysql不同版本数据库同步]mysql数据库主从同步,master和slave上的mysql必须版本一样吗,如果不一样会有什么结果?...

在线QQ客服:1922638专业的SQL Server、MySQL数据库同步软件497950890Slave_SQL_Running: No mysql同步故障解决如果数据不同步可以尝试该资料mysql> show slave status\GSlave_IO_Running: YesSlave_SQL_Running: NoLast_Errno: 1062….Seconds_Behind_Master:NU…

不可变集合相比可变集合_简单的基准测试:不可变集合VS持久集合

不可变集合相比可变集合通常,您需要向集合中添加新元素。 因为您是一个优秀而谨慎的开发人员,所以您希望尽可能保持不变。 因此,向不可变集合中添加新元素将意味着您必须创建一个新的不可变集合,其中包含原始集合的所有元素以及新…

C++ 面试被问到的“左值引用和右值引用”

点击蓝字关注我们1.左值和右值在C11中可以取地址的、有名字的就是左值,反之,不能取地址的、没有名字的就是右值(将亡值或纯右值)。举个例子,int a bc, a 就是左值,其有变量名为a,通过&a可以…

php如何解释xml,PHP – 如何解析这个xml?

我正在尝试解析下面的XML,以便最终得到一个看起来像样本的数组……我很难弄清楚如何获取标签内部的属性以输出我想要的方式它…XML我想要的数组::注意添加的数组元素Array[cust] > Array[rid] > 999999[member_id] > 12345[lname] > Doe[fname] > John[address]…

jug java_架构大型企业Java项目–我的虚拟JUG会话

jug java昨天我很荣幸被邀请参加虚拟JUG 。 这是一个很大的荣誉,其原因有很多:首先,我是vJUG董事会的一员,其次,因为这是我第二次向这个对Java感兴趣的伟大团队做演讲。 受到邀请总是很高兴。 架构大型企业Java项目 过…

初学者宝典:C语言入门基础知识大全

点击蓝字关注我们01C语言程序的结构认识用一个简单的c程序例子,介绍c语言的基本构成、格式、以及良好的书写风格,使小伙伴对c语言有个初步认识。例1:计算两个整数之和的c程序:#include main() {int a,b,sum; a20; /*定义变量a,b&a…

php怎么使用多个数据库,怎么在php项目中使用CI对多个数据库进行操作

怎么在php项目中使用CI对多个数据库进行操作发布时间:2020-12-19 16:57:21来源:亿速云阅读:87作者:Leah今天就跟大家聊聊有关怎么在php项目中使用CI对多个数据库进行操作,可能很多人都不太了解,为了让大家更…

qt如何捕获应用程序输出_企业应用程序中需要捕获的5大Java性能指标

qt如何捕获应用程序输出有兴趣了解如何使用AppDynamics捕获这些Java性能指标吗? 立即开始免费试用 ! 前几篇文章介绍了应用程序性能管理(APM),并指出了有效实施APM战略的挑战。 本文通过回顾五个顶级性能指标来构建这…

C语言入门笔记,推荐收藏!

点击蓝字关注我们C语言一经出现就以其功能丰富、表达能力强、灵活方便、应用面广等特点迅速在全世界普及和推广。C语言不但执行效率高而且可移植性好,可以用来开发应用软件、驱动、操作系统等。C语言也是其它众多高级语言的鼻祖语言,所以说学习C语言是进…

php.c drcom,校园网绕过Drcom安装自动登录程序到路由器

简单记录一下,怎么在路由器上安装drcom脚本,实现自动登陆,一个路由器,全寝室都可以使用的方法。安装固件:我这里使用的是newifi mini型号的路由器下载后,插拔一次路由器,按下路由器上的reset按钮…

jax-rs jax-ws_如何以大数据的JAX-RS响应的形式将JPA结果流化/序列化

jax-rs jax-ws有时,有必要通过JPA检索大型数据集(例如,超过1,000,000条记录),并将它们填充到java.util.List的单个实例中是有风险的(内存障碍)。 因此,这是一个快速的解决方案&#…

php 字符串 字典序序排序,C++ 怎么实现字典序排序法,自然排序

C 如何实现字典序排序法,自然排序类似PHP的natcasesort函数,整了一天没有头绪.数组是vector排序前:[0] > IMG0.png[1] > IMG3.png[2] > img1.png[3] > img10.png[4] > img12.png[5] > img2.png排序后:[0] > IMG0.png[1] > img1.png[2] > img2.png[3…

如何优雅地利用C++编程从1乘到20?

点击蓝字关注我们知乎的一个问题&#xff1a;答主&#xff1a;小白白。数学家版本&#xff1a;&#xff08;简单利索&#xff0c;深藏功与名&#xff09;#include <iostream> #include <cmath> int main() {std::cout << std::tgamma(20 1) << std::e…

春天猫rtsy_春天:注入列表,地图,可选对象和getBeansOfType()陷阱

春天猫rtsy如果您使用Spring框架超过一个星期&#xff0c;那么您可能已经知道此功能。 假设您有多个bean实现了给定的接口。 尝试仅自动连接此类接口的一个bean注定会失败&#xff0c;因为Spring不知道您需要哪个特定实例。 您可以通过使用Primary批注来指定一个优先于其他实现…

matlab内维尔差值代码,计算方法上机练习数值积分(包括两次作业).PDF

计算方法上机练习 数值积分(包括两次的作业 )马骢问题&#xff1a; 《计算方法引论》pp.132–133 练习分析&#xff1a;在实际应中基本的数值积分&#xff0c;可 以分为以下种类 &#xff1a;• 牛顿型 &#xff1a;在给定有 限区 间上求等距节 点上 的函数值 。如牛顿-柯茨法则…