登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
登录
注册
代码拉取完成,页面将自动刷新
开源项目
>
数据库相关
>
数据库开发包
&&
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
2.3K
Star
11.6K
Fork
3.5K
GVP
baomidou
/
mybatis-plus
代码
Issues
13
Pull Requests
0
统计
流水线
服务
JavaDoc
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
我知道了,不再自动展开
194
simple-query 让简单的查询更简单
已合并
阿超:3.0
baomidou:3.0
阿超
创建于 2021-11-09 19:07
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
### 该Pull Request关联的Issue ### 修改描述 封装了下业务中常用的查表方法 ### 测试用例 ```java package com.baomidou.mybatisplus.test.toolkit; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.toolkit.Assert; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.toolkit.SimpleQuery; import com.baomidou.mybatisplus.extension.toolkit.SqlHelper; import com.baomidou.mybatisplus.test.BaseDbTest; import com.baomidou.mybatisplus.test.rewrite.Entity; import com.baomidou.mybatisplus.test.rewrite.EntityMapper; import org.junit.jupiter.api.Test; import java.util.*; /** * 简单查询工具类测试 * * @author <achao1441470436@gmail.com> * @since 2021/11/9 18:30 */ public class SimpleQueryTest extends BaseDbTest<EntityMapper> { @Test public void testList() { // 我要这张表里的ids List<Long> entityIds = SimpleQuery.list(Wrappers.lambdaQuery(), Entity::getId); Assert.isTrue(entityIds.equals(Arrays.asList(1L, 2L)), "Ops!"); // 可叠加后续操作 List<String> names = SimpleQuery.list(Wrappers.lambdaQuery(), Entity::getName, e -> Optional.ofNullable(e.getName()).map(String::toUpperCase).ifPresent(e::setName)); Assert.isTrue(names.equals(Arrays.asList("RUBEN", "A CHAO")), "Ops!"); } @Test public void testMap() { // 我要这个表里对应条件的用户,用id作为key给我一个map Map<Long, Entity> idEntityMap = SimpleQuery.keyMap(Wrappers.<Entity>lambdaQuery().eq(Entity::getId, 1L), Entity::getId); // 校验结果 Entity entity = new Entity(); entity.setId(1L); entity.setName("ruben"); Assert.isTrue(idEntityMap.equals(Collections.singletonMap(1L, entity)), "Ops!"); // 如果我只想要id和name组成的map Map<Long, String> idNameMap = SimpleQuery.map(Wrappers.lambdaQuery(), Entity::getId, Entity::getName); // 校验结果 Map<Long, String> map = new HashMap<>(1 << 2); map.put(1L, "ruben"); map.put(2L, "a chao"); Assert.isTrue(idNameMap.equals(map), "Ops!"); // 同样支持叠加后续操作 // SimpleQuery.keyMap(Wrappers.lambdaQuery(), Entity::getId, System.out::println, System.out::println); } @Test public void testGroup() { // 我需要相同名字的用户的分为一组,再造一条数据 BaseMapper<Entity> mapper = SqlHelper.getMapper(Entity.class); Entity entity = new Entity(); entity.setId(3L); entity.setName("ruben"); mapper.insert(entity); // 简单查询 Map<String, List<Entity>> nameUsersMap = SimpleQuery.group(Wrappers.lambdaQuery(), Entity::getName); // 校验结果 Map<String, List<Entity>> map = new HashMap<>(1 << 2); Entity chao = new Entity(); chao.setId(2L); chao.setName("a chao"); map.put("a chao", Collections.singletonList(chao)); Entity ruben = new Entity(); ruben.setId(1L); ruben.setName("ruben"); Entity ruben2 = new Entity(); ruben2.setId(3L); ruben2.setName("ruben"); map.put("ruben", Arrays.asList(ruben, ruben2)); Assert.isTrue(nameUsersMap.equals(map), "Ops!"); } @Override protected String tableDataSql() { return "insert into entity(id,name) values(1,'ruben'),(2,'a chao');"; } @Override protected List<String> tableSql() { return Arrays.asList("drop table if exists entity", "CREATE TABLE IF NOT EXISTS entity (" + "id BIGINT NOT NULL," + "name VARCHAR(30) NULL DEFAULT NULL," + "PRIMARY KEY (id))"); } } ``` ### 修复效果的截屏
怎样手动合并此 Pull Request
git checkout 3.0
git pull https://gitee.com/VampireAchao/mybatis-plus.git 3.0
git push origin 3.0
评论
1
提交
1
文件
2
检查
代码问题
0
批量操作
展开设置
折叠设置
审查
Code Owner
审查人员
DevYang
devyang
小锅盖
TaoYu_cd
yuxiaobin
hadoobing
zengzhihong
zengzhihong
Dervish
tld2018
凯凯大魔王
kaikaidamowang
东平王北星
ls9527
keep
zengzefeng
阿超
VampireAchao
青苗
jobob
miemie
miemieyaho
你有医保你先上
h825944942
未设置
最少人数
0
测试
DevYang
devyang
小锅盖
TaoYu_cd
yuxiaobin
hadoobing
zengzhihong
zengzhihong
Dervish
tld2018
凯凯大魔王
kaikaidamowang
东平王北星
ls9527
keep
zengzefeng
阿超
VampireAchao
青苗
jobob
miemie
miemieyaho
你有医保你先上
h825944942
未设置
最少人数
0
优先级
不指定
严重
主要
次要
不重要
标签
标签管理
未设置
关联 Issue
未关联
Pull Request 合并后将关闭上述关联 Issue
里程碑
未关联里程碑
mybatis-plus 4.0 重构计划
参与者
(2)
Java
1
https://gitee.com/baomidou/mybatis-plus.git
git@gitee.com:baomidou/mybatis-plus.git
baomidou
mybatis-plus
mybatis-plus
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册