SpringBoot MybatisPlus selectOne的坑

目录

一、问题

二、问题解决

三、其他方法


一、问题

selectOne在查询多条数据时会报错,查询语句并不会加 limit 1。

复制代码
One record is expected, but the query result is multiple records。

二、问题解决

在QueryWrapper上添加如下:

java 复制代码
QueryWrapper<T> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq(SysTenant.COL_USERNAME, username)
                .or().eq(SysTenant.COL_PHONE, username)
                .or().eq(SysTenant.COL_EMAIL, username)
                .last("limit 1");
        return mapper.selectOne(queryWrapper);

这样不但查询时会只查一条提升性能,selectOne也不再报错。

三、其他方法

java 复制代码
 //查询到多条数据的情况下只取第一条
 FileDto fileDto = fileMapper.selectOne(queryWrapper);//这个报异常
   
 
 FileDto fileDto1 = getOne(queryWrapper, false);//不抛出异常,从多个结果去一条并记录日志

产生原因:

使用selectOne方法查询数据库,在数据中发现多条数据,然后出现报错。

解决:替换IServer中的getOne方法,

getOne(queryWrapper,Boolean)

Boolean

true :抛出异常

false:不抛出异常,从多个结果中取一条并记录日志即可。

总结到此!

相关推荐
悟能不能悟9 小时前
java map判断是否有key,get(key)+x,否则put(key,x)的新写法
java·开发语言
用户4099322502129 小时前
Vue3中v-if与v-for为何不能在同一元素上混用?优先级规则与改进方案是什么?
前端·vue.js·后端
webbodys9 小时前
Python文件操作与异常处理:构建健壮的应用程序
java·服务器·python
石工记9 小时前
对称加密 vs 非对称加密图解详解
java·网络安全
blurblurblun9 小时前
Go语言特性
开发语言·后端·golang
Y.O.U..9 小时前
Go 语言 IO 基石:Reader 与 Writer 接口的 “最小设计” 与实战落地
开发语言·后端·golang
冒泡的肥皂9 小时前
25年AI我得DEMO老师
人工智能·后端
茹鲸9 小时前
我开发了一个文件智能分类工具,彻底解决了桌面文件杂乱的问题
后端
思成Codes9 小时前
Gin 框架:*gin.Engine 主要方法
后端·golang·gin
举大栗子9 小时前
Hikari数据库连接池部分常用参数解析
后端