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:不抛出异常,从多个结果中取一条并记录日志即可。

总结到此!

相关推荐
The Sheep 20231 天前
可视化命中测试
java·服务器·前端
小小工匠1 天前
Vibe Coding - Claude Code 做 Java 项目 AI 结对编程最佳实践
java·结对编程·claude code
源码获取_wx:Fegn08951 天前
基于springboot + vue酒店预约系统
java·vue.js·spring boot·后端·spring
__万波__1 天前
二十三种设计模式(十九)--备忘录模式
java·设计模式·备忘录模式
我想问问天1 天前
【从0到1大模型应用开发实战】03|写一个可解释的RAG规则检索器
后端·aigc
小兔崽子去哪了1 天前
Spring AOP 专题
java·spring boot·spring
豆浆Whisky1 天前
6小时从0到1:我用AI造了个分片SQL生成器
后端·sql·ai编程
菩提祖师_1 天前
微信小程序茶园茶农文化交流系统
java·javascript·网络
强子感冒了1 天前
Java 泛型的学习笔记
java·笔记·学习
萧曵 丶1 天前
ThreadLocal 原理及内存泄漏详解
java·多线程·threadlocal