登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
登录
注册
9月20日,Gitee × 模力方舟来成都了!聚焦 AI 应用在开发范式、算力架构、交互设计、硬件选型等跨场景创新实践,点击立即报名~
代码拉取完成,页面将自动刷新
开源项目
>
数据库相关
>
数据库开发包
&&
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
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
我知道了,不再自动展开
198
优化SimpleQuery,处理了值为空的情况,太牛了
已合并
阿超:3.0
baomidou:3.0
阿超
创建于 2021-12-25 16:24
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
### 该Pull Request关联的Issue 暂无关联`Issue` ### 修改描述 优化SimpleQuery,处理了值为空的情况: 之前的情况: 假设数据库中表数据: | id | name | |----|--------| | 1 | ruben | | 2 | null | 我们构建一个`Enitity`(向`miemie`大佬致敬) ```java package com.baomidou.mybatisplus.test.rewrite; import lombok.Data; import java.io.Serializable; /** * @author miemie * @since 2020-06-23 */ @Data public class Entity implements Serializable { private static final long serialVersionUID = 6962439201546719734L; private Long id; private String name; } ``` 使用`SimplerQuery`进行查询 ```java Map<Long, String> idNameMap = SimpleQuery.map(Wrappers.lambdaQuery(), Entity::getId, Entity::getName); ``` 期望的数据格式如下:  这样我就可以通过`idNameMap.get(1L)`获取到`id`为`1L`对应的表数据中`name`字段的值,非常便利 但是如果是之前的版本,则会抛出`NullPointerException`(下方简称`NPE`)  原因是因为默认使用`Collectors#toMap`这个函数  它调用的是`HashMap#merge`  其中判断了如果`value`为空,则抛出`NPE`  而此处我期望的数据,它是允许`name`为`null`的 因此我进行了一点小修改:   然后再次执行,成功得到我们期望的值  还有一处修改,也是相同的道理,我期望得到如下结果: 这里获取到的`map`,`key`为表中的`name`,`value`则是对应`key`中`name`相同的数据组成的集合 为了方便测试,我再新增了一条数据: ```java // SqlHelper#getMapper是根据`entity`获取对应`mapper`的方法 BaseMapper<Entity> mapper = SqlHelper.getMapper(Entity.class); Entity entity = new Entity(); entity.setId(3L); entity.setName("ruben"); mapper.insert(entity); ``` 开始查询: ```java Map<String, List<Entity>> nameUsersMap = SimpleQuery.group(Wrappers.lambdaQuery(), Entity::getName); ``` 期望结果如下:  实际还是抛出了`NPE`:  这是因为原来使用的`Collectors#groupingBy`,它也对`key`进行了判空处理,实际上我们并不想丢掉这些数据   因为可以根据`nameUsersMap.get(null)`去顺带获取`name`为`null`的数据,最起码,个别`name`为`null`的数据不能影响我取其他的值,说白了就是你别给我抛出`NPE`... 所以我又施展了一点小修改:  测试成功通过!  当然我写的代码还是有一定的优化空间的,各位`dalao`好汉欢迎舔砖`Java`~各位的意见和建议我也会考虑采纳的 `Mp`陪伴我走过了两年,今天是圣诞节,祝`Mybatis-Plus`全体开发者圣诞快乐 :heart: !!! ### 测试用例 `com.baomidou.mybatisplus.test.toolkit.SimpleQueryTest` ### 修复效果的截屏 
怎样手动合并此 Pull Request
git checkout 3.0
git pull https://gitee.com/VampireAchao/mybatis-plus.git 3.0
git push origin 3.0
评论
0
提交
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 重构计划
参与者
(1)
Cherry-pick 提交
Cherry-pick 可以将
特定提交(Commit)
从某个分支挑选并应用到另一个分支,实现快速集成特定更改,而无需合并整个分支。
请选择应用 Cherry-pick 提交 (Commit) 的目标分支
新建分支
当前账号不存在 Fork 仓库,建议 cherry-pick 到 Fork 仓库。
Fork 仓库
提交列表
Commit SHA
Commit Message
基于 Cherry-pick 后的分支发起 Pull Request
取消
Cherry-pick
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 帐号,请先登录后再操作。
立即登录
没有帐号,去注册