BeetlSQL 3.0.7 发布,新增 LambdaSubQuery

栏目: 软件资讯 · 发布时间: 5年前

内容简介:新增LambdaSubQuery,来源于 https://gitee.com/xiandafu/beetlsql/issues/I1WRHZ 修复代码生成POJO类的错误 <dependency> <groupId>com.ibeetl</groupId> <artifactId>beetlsql</artifactId> <version...
  • 新增LambdaSubQuery,来源于 https://gitee.com/xiandafu/beetlsql/issues/I1WRHZ
  • 修复代码生成POJO类的错误
<dependency>
  <groupId>com.ibeetl</groupId>
  <artifactId>beetlsql</artifactId>
  <version>3.0.7-RELEASE</version>
</dependency

关于LambdaSubQuery使用说明如下,使用@SubQuery标注mapper方法

public  interface AnyMapper extends BaseMapper<User>{
/* 构造一个公共的子查询Lambda,由lambda#allUserInDepartment构成
*/
@SubQuery
public LambdaQuery<User> allUserInDepartment(Integer deptId);
}

如上allUserInDepartment方法返回一个LambdaQuery(是LambdaSubQuery),lambda#allUserInDepartment提供了子查询语句,其内容如下

allUserInDepartment
===
    
    select * from sys_user where department_id=#{deptId}

因此,BeetlSQL实际Lambda查询的时候,构成的 sql 其实如下

select * from (select * from sys_user where department_id=xxx) where .....

这样的好处是可以把复杂的查询转成简单的Lambda查询


LambdaQuery<User> lambdaQuery = anyMapper.allUserInDepartment(1);
List<User> newList = lambdaQuery.andEq(User::getAge,42).select();
Assert.assertEquals(0,newList.size());

如上查询,对应的sql实际上是

┏━━━━━ Debug [sql.SELECT * FROM ( select * from sys_user where d...] ━━━
┣ SQL:	 SELECT * FROM ( select * from sys_user where department_id=? ) _t WHERE age = ? 
┣ 参数:	 [1, 42]
┣ 位置:	 org.beetl.sql.core.mapper.SubQueryCommonTest.commonLambda(SubQueryCommonTest.java:32)
┣ 时间:	 1ms
┣ 结果:	 [0]
┗━━━━━ Debug [sql.SELECT * FROM ( select * from sys_user where d...] ━━━

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算群体智能基础

计算群体智能基础

恩格尔伯里特 / 谭营 / 2009-10 / 69.00元

《计算群体智能基础》全面系统地介绍了计算群体智能中的粒子群优化(PSO)和蚁群优化(ACO)的基本概念、基本模型、理论分析及其应用。在简要介绍基本优化理论和总结各类优化问题之后,重点介绍了社会网络结构如何在个体间交换信息以及个体聚集行为如何形成一个功能强大的有机体。在概述了进化计算后,重点论述了粒子群优化和蚁群优化的基本模型及其各种变体,给出了分析粒子群优化模型的一种通用方法,证明了基于蚂蚁行为实......一起来看看 《计算群体智能基础》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具