原文由作者授权,首发在奇安信攻防社区 https://forum.butian.net/share/1528 JOOQ是一个ORM框架,利用其生成的Java代码和流畅的API,可以快速构建有类型约束的安全的...0x01 关于JOOQ JOOQ是一个ORM框架,利用其生成的Java代码和流畅的API,可以快速构建有类型约束的安全的SQL语句。...它作为一个静态的工厂去生成数据库表表达式,列表达式,条件表达式和其他查询部分。...例如mybatis里常见的like查询,经常会出现SQL注入问题,jooq提供的表达式已经进行了相应的处理,使用也比较方便: result=result.and(jooq.NAME.like("%"...0x03 其他 一般情况下,为了避免错误使用@PlainSQL注解标记的API导致SQL注入问题,可以引入jooq-checker来进行检查: org.jooq
) 在阻塞LoadBalancer客户端中添加了基于 sticky-session 请求的支持(#901) Spring Cloud Config 使用ConfigData时添加的TLS支持(#1689...(#703) 添加对多个默认查询标记的支持。(#684) Spring Cloud Gateway 添加服务实例id Cookie的支持(#2070) HttpClient代理类型是可自定义的。...Bug Fixes 当SQLException无法翻译时,JooqExceptionTranslator将null异常传递给jOOQ #25717 如果配置了多个架构或数据脚本位置,并且在一个位置上找不到资源...#25483 当使用配置为过滤器的执行器和控制器时,应用程序无法启动 #25449 在Spring Boot 2.4中@EntityScan不支持属性替换 #25436 SpringApplication...#25513 突出显示参考文件中致动器API文件的链接 #25510 修复gradle插件文档中的属性名 #25454 修复文档中的语法错误 #25411 修复生成信息目标描述中的措辞错误 #25385
,JOOQ还可以用Java代码来编写SQL语句,利用IDE的代码自动补全功能,自动提示表名和字段名,减少程序员记忆负担,还可以在元数据发生变化时发生编译错误,提示程序员修改相应的SQL语句。...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...MyBatis提供了"SQL语句构建器"来帮助开发人员构造SQL语句,但和QueryDSL/JOOQ/Ebean差很多,不能提示表名和字段名,语法也显得累赘不像SQL。...DSL编程里面,字段被逆向工程为一个java类的属性,数据库结构改变之后,作为java代码一部分的查询语句会发生编译错误,提示开发人员进行修改,可以减少大量bug,减轻测试的负担,提高软件的可靠性和质量...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。
基于CLI的测试 从Spring Boot的CLI中删除了测试支持,现在建议你使用Maven或Gradle构建应用程序,去使用它们提供的丰富的测试支持吧。...ps:其实就是因为webflux来了,只能把servlet和webflux区分开来。 Mustache 模板默认文件扩展名 过去Mustache模板的默认的文件扩展名是.html。...jOOQ Spring Boot现在可以根据DataSource自动检测出jOOQ方言(类似于JPA方言)。 此外,还引入了@JooqTest用于只有jOOQ才能hold的测试场景。...Spring WebFlux支持错误约定 Spring Boot现在让WebFlux的错误约定和MVC保持一致就像使用MVC一样:默认视图和JSON响应错误,自定义错误视图等等。...支持自动配置的模板化欢迎页 Spring Boot 2.0 现在支持静态和模板化两种欢迎页类型。
数据库初始化 我们借助jooq-codegen-maven插件来自动生成数据库相关的代码,对这一段逻辑感兴趣的小伙伴可以参考博文:【DB 系列】Jooq 代码自动生成 后文中使用的表结构如下 DROP...InsertQuery 方式 上面两种写法比较常见,而直接使用 InsertQuery 的方式,在实际的业务开发中可能并没有上面的优雅,但某些特殊场景下还是很有用的 /** * 不使用自动生成的代码来原生插入数据...* * @param id * @param name * @return */ public boolean save3(int id, String name) { // 当不使用自动生成的对象时...,重点在上面的实现中,并没有利用自动生成的代码,如 table: DSL.table(表名) field: DSL.field(列名,类型) 通过上面的的 case,我们可以知道在不自动生成 DB 对应的代码前提下...一灰灰 Blog 尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现 bug 或者有更好的建议,欢迎批评指正,不吝感激 下面一灰灰的个人博客,记录所有学习和工作中的博文,
(2)使用没有父POM的Spring Boot (3)使用Spring Boot Maven插件 1.3、摇篮 1.4、蚂蚁 1.5、首发 2、构建你的代码 2.1、使用“默认”包 2.2、查找主要应用程序类...静态内容 (4)模板引擎 (5)错误处理 (6)网页过滤器 5.3、JAX-RS和泽西岛 5.4、嵌入式Servlet容器支持 (1)Servlet,过滤器和监听器 将Spring Servlet,过滤器和监听器注册为...Web控制台 (1)更改H2 Console的路径 7.5、使用jOOQ (1)代码生成 (2)使用DSLContext (3)jOOQ SQL方言 (4)定制jOOQ 8、与NoSQL Technologies...Spring应用程序 20.3、测试Spring Boot应用程序 (1)检测Web应用程序类型 (2)检测测试配置 (3)不包括测试配置 (4)使用运行的服务器进行测试 (5)嘲笑和侦察豆 (6)自动配置的测试...2.1、在构建时自动扩展属性 (1)使用Maven自动扩展属性 (2)使用Gradle的自动属性扩展 2.2、外部化配置 SpringApplication 2.3、更改应用程序的外部属性的位置 2.4
Byte Buddy:使用“流式API”进一步简化字节码生成。 代码分析 软件度量和质量评估工具。 Checkstyle:对编程规范和标准进行静态分析。...Flyway:使用Java API轻松完成数据库迁移。 H2:小型SQL数据库,以内存操作著称。 JDBI:便捷的JDBC抽象。 jOOQ:基于SQL schema生成类型安全代码。...JRebel:商用软件,无需重新部署可即时重新加载代码及配置。 Lombok:代码生成器,旨在减少Java冗余代码。 RxJava:使用JVM中可观察序列,创建异步、基于事件应用程序的函数库。...Apache Velocity:提供HTML页面模板、email模板和通用开源代码生成器模板。 FreeMarker:通用模板引擎,不需要任何重量级或自己使用的依赖关系。...Grails:Groovy框架,旨在提供一个高效开发环境,使用约定而非配置、没有XML并支持混入(mixin)。 Play: 使用约定而非配置,支持代码热加载并在浏览器中显示错误。
Byte Buddy:使用“流式API”进一步简化字节码生成。 ---- 代码分析 软件度量和质量评估工具。 Checkstyle:对编程规范和标准进行静态分析。...jOOQ:基于SQL schema生成类型安全代码。 Presto:针对大数据的分布式SQL查询引擎。 Querydsl:针对Java的类型安全统一查询。...JRebel:商用软件,无需重新部署可即时重新加载代码及配置。 Lombok:代码生成器,旨在减少Java冗余代码。 RxJava:使用JVM中可观察序列,创建异步、基于事件应用程序的函数库。...---- 模版引擎 对模板中表达式进行替换的工具。 Apache Velocity:提供HTML页面模板、email模板和通用开源代码生成器模板。...Grails:Groovy框架,旨在提供一个高效开发环境,使用约定而非配置、没有XML并支持混入(mixin)。 Play: 使用约定而非配置,支持代码热加载并在浏览器中显示错误。
Flyway:使用Java API轻松完成数据库迁移。 H2:小型SQL数据库,以内存操作著称。 JDBI:便捷的JDBC抽象。 jOOQ:基于SQL schema生成类型安全代码。...Joda-Time:Java 8出现之前,它是日期、时间处理的标准函数库。 Time4J:Java高级日期、时间函数库。 依赖注入 帮助代码实现控制反转模式的函数库。...JRebel:商用软件,无需重新部署可即时重新加载代码及配置。 Lombok:代码生成器,旨在减少Java冗余代码。 RxJava:使用JVM中可观察序列,创建异步、基于事件应用程序的函数库。...Apache Velocity:提供HTML页面模板、email模板和通用开源代码生成器模板。 FreeMarker:通用模板引擎,不需要任何重量级或自己使用的依赖关系。...Grails:Groovy框架,旨在提供一个高效开发环境,使用约定而非配置、没有XML并支持混入(mixin)。 Play: 使用约定而非配置,支持代码热加载并在浏览器中显示错误。
30.6使用jOOQ Java面向对象查询(jOOQ)是Data Geekery的一个流行产品, 它从您的数据库生成Java代码,并允许您通过其流畅的API构建类型安全的SQL 查询。...商业版和开源版都可以与Spring Boot一起使用。 30.6.1代码生成 要使用jOOQ类型安全查询,您需要从数据库模式生成Java类。您可以按照jOOQ用户手册中的说明进行 操作。...如果您使 用 jooq-codegen-maven 插件并且还使用 spring-boot-starter-parent “父POM”,则可以安全地省略插件的 标记。... 30.6.2使用DSLContext jOOQ提供的流畅API通过 org.jooq.DSLContext 接口启动。...30.6.4自定义jOOQ 通过定义自己的 @Bean 定义可以实现更高级的自定义,这些定义在创建jOOQ Configuration 时使用。
相信大家都有过这样的体会,我们在项目工程中使用Mybatis进行数据库相关代码的编写时,为了提高工程效率,一般会在数据库模型设计完成后,一次性使用Mybatis代码插件(如:mybatis-generator...而通过这样的方式,虽然在工程效率上提高了很多,但是从代码的简洁和优雅性上来说就会让人感觉特别的啰嗦,因为自动生成的代码并不完全都是你在项目中能够用得到的。...接下来我们就来一起看看,如何在SpringBoot的项目中集成和使用JOOQ吧!...而在具体的业务逻辑中,需要操作数据库时我们就可以很方便的使用这些自动生成的代码来进行操作,例如,我们需要在业务代码中执行insert操作,代码如下: @Slf4j @Service public class...代码中,我们需要通过自动代码生成的类指定表名,并以面向对象的语法方式组装查询条件后就可以完成查询操作了!
接下来我们开始进入 jooq 的增删改查的使用姿势系列,本篇将主要介绍如何利用 jooq 来实现添加数据 I....数据库初始化 我们借助jooq-codegen-maven插件来自动生成数据库相关的代码,对这一段逻辑感兴趣的小伙伴可以参考博文:【DB 系列】Jooq 代码自动生成 后文中使用的表结构如下 DROP...InsertQuery 方式 上面两种写法比较常见,而直接使用 InsertQuery 的方式,在实际的业务开发中可能并没有上面的优雅,但某些特殊场景下还是很有用的 /** * 不使用自动生成的代码来原生插入数据...* * @param id * @param name * @return */ public boolean save3(int id, String name) { // 当不使用自动生成的对象时...,重点在上面的实现中,并没有利用自动生成的代码,如 table: DSL.table(表名) field: DSL.field(列名,类型) 通过上面的的 case,我们可以知道在不自动生成 DB 对应的代码前提下
-- 自动生成的类的包名,以及路径 --> com.git.hui.boot.jooq.h2...,会得到生成的代码 2....小结 到此,SpringBoot 集成 jooq 的 demo 已经完成,并提供了基础的 CURD,整体来看,集成比较简单,需要注意的是代码自动生成,我们这里是借助 maven 插件来实现代码自动生成的..., 此外也可以通过官方提供的jooq-xx.jar + xml配置文件来自动生成;后面单独捞一篇博文给与介绍 从 jooq 的使用姿势来看,最大的感官就是类 sql 的链式写法,比较的直观,阅读友好;此外需要注意的是自动生成的实体...一灰灰 Blog 尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现 bug 或者有更好的建议,欢迎批评指正,不吝感激 下面一灰灰的个人博客,记录所有学习和工作中的博文,
新的BinderAPI 也可以@ConfigurationProperties直接在你自己的代码之外使用。...Spring Boot 现在需要 Gradle 4.x. 如果您要升级使用 Gradle 的项目,请查看迁移指南。...现在还使用 Spring REST Docs 生成了广泛的 REST API 文档,并随每个版本发布。...@JooqTest是新引入的注解用来简化那些只有 JOOQ 必须被使用的测试。...上下文路径记录 当使用嵌入式容器时,当您的应用程序启动时,上下文路径将与 HTTP 端口一起记录。
,本次更新内容包括了 29 个错误修复,15个文档改进和31个依赖项升级,共计75项内容,不可谓不丰富。...定义为ConnectionFactory,会缺少RabbitMQ监控指标的问题 8、修复当使用JPA延迟存储库时,上下文中的ContextRefreshedEvent可能会导致死锁的问题 9、修复Gradle...InvalidConfigDataPropertyException的问题 23、修复当spring.mvc.pathmatch.matching-strategy被设置为路径匹配策略模式时,监听服务的错误处理就会被中断的问题...内容的问题 29、修复使用了错误的类加载器导致Hazelcast执行失败的问题 文档改进 1、更新Gradle插件文档,推荐maven-publish插件而不是maven插件 2、支持Kafka Streams...,12个文档改进和26个依赖项升级,共计46项内容,其中主要修复的bug有: 修复 在通过jOOQ访问数据库之前,Flyway或Liquibase执行动作可能尚未完成而导致访问失败的问题 修复缺少新版本
就在今天Spring Boot 2.0.0.RELEASE正式发布,今天早上在发布Spring Boot2.0的时候还出现一个小插曲,将Spring Boot2.0同步到Maven仓库的时候出现了错误,...Flyway 5 Hibernate 5.2 Gradle 3.4 Thymeleaf 3。...JOOQ 既吸取了传统ORM操作数据的简单性和安全性,又保留了原生sql的灵活性,它更像是介于 ORMS和JDBC的中间层。...对于喜欢写sql的码农来说,JOOQ可以完全满足你控制欲,可以是用Java代码写出sql的感觉来。 Lettuce Lettuce是一个可伸缩的线程安全的Redis客户端,用于同步,异步和反应使用。...写在最后 前两天在看池建强老师文章时,发现老师刚好也介绍了Spring Boot2.0,其中有这么一个观点:Java 语言为什么能够长期占据编程兵器排行榜第一名的位置呢?因为命好。
领取专属 10元无门槛券
手把手带您无忧上云