内容简介:新增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...] ━━━
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- WookTeam 1.2 发布,新增知识库markdown编辑器,新增知识库协作更新通知
- GCC 8.1 发布,新增大量功能
- uiw 1.4.0 发布,新增日历控件
- Novel 1.5.0 发布,新增参数管理
- Element 2.3.3 发布,新增多个属性
- easyopen 1.8.1 发布,新增监控页面
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。