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

总结到此!

相关推荐
毕设源码-赖学姐几秒前
【开题答辩全过程】以 “实惠”药房管理系统为例,包含答辩的问题和答案
java
共享家95272 分钟前
测试常用函数(一)
java·前端·javascript
不会写代码的里奇2 分钟前
从零开发基于DeepSeek的端侧离线大模型语音助手:全流程指南
c++·后端·音视频
廋到被风吹走4 分钟前
【JAVA】【JDK】java8版本之后各个版本调整
java·开发语言
酸菜牛肉汤面6 分钟前
17、什么是脏读?幻读?不可重复读?
java·数据库·mysql
雨中飘荡的记忆6 分钟前
MyBatis结果映射模块详解
java·mybatis
不能放弃治疗9 分钟前
发消息逻辑写在MySQL事务中,导致消费逻辑Bug
后端
Coder_Boy_9 分钟前
基于SpringAI的智能AIOps项目:微服务与DDD多模块融合设计概述
java·运维·人工智能·微服务·faiss
Cache技术分享10 分钟前
279. Java Stream API - Stream 拼接的两种方式:concat() vs flatMap()
前端·后端