记录springboot bug

mybatis bug

mapper 自动生成xml 产生错误

首先我这个bug十分奇怪,不管是报错,还是解决方法

首先,我还原我bug的过程

我首先要在 ordersMapper生成一个方法

本来是这样的方法

bash 复制代码
@Mapper
public interface OrdersMapper extends BaseMapper<Orders> {
    List<GoodsSalesDTO> getSalesTop10(LocalDateTime atStartOfDay, LocalDateTime atStartOfDay1);
}

我不小心把返回值改成了如下

bash 复制代码
@Mapper
public interface OrdersMapper extends BaseMapper<Orders> {
    GoodsSalesDTO getSalesTop10(LocalDateTime atStartOfDay, LocalDateTime atStartOfDay1);
}

我们可以看到就是这里的返回类型不同

然后问题的关键出来了,我用mybatisX的自动生成xml方法的方式,生成了我写错方法的mapper.xml的方法

如下

bash 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
	 <select id="getSalesTop10" resultType="com.sky.dto.GoodsSalesDTO">
     		select od.name, sum(od.number) number from order_detail od,orders o where od.order_id = o.id and o.status = 5
	        <if test="begin != null"> and o.order_time > #{begin} </if>
	        <if test="end != null"> and o.order_time < #{end} </if>
	        group by od.name order by number desc limit 0,10
    </select>
</mapper>

一切都很稀松平常把,这样生成也没什么问题

但是最奇怪的地方来了,他的报错,不是报错ordersMapper而是其他的mapper

如下报错

他的报错竟然是其他的category相关的类,mapper 和service

这就很奇怪了,到底什么意思

解决方法

而且解决也很奇怪,先是改正mapper类方法的返回值

然后重新生成这个方法

然后加入sql

然后问题就解决了???,而且还有一个奇怪的点在于,他重新生成的这个方法,和我弄错返回类型的方法生成的xml方法是一样的

我们可以做一个对比

发现没什么不同

问题出现的原因

那么我们来看这里的问题,我发现最后出现的问题,不关生成的问题,问题在于我的sql写错了,有一个报错,然后导致报错,但是他的报错有点牛头不对马嘴的感觉

我们来看我哪里出了问题

因为这里的格式写错了,所以这里就会有问题

总结

所以以后出现了这种问题,首先我应该去重试一下刚刚写的代码,如果重试了几次,还有错,说明不是我写的有问题,然后我奇怪就奇怪他这里为什么这么报错,感觉把我带歪了,我以为我categoryMapper出了什么问题,但我有点想法,我估计是categoryMapper这些类,再这个ordersmapper之后才加载,然后ordersMapper的xml代码写错了,所以导致它出错了,所以最后,出了什么问题,第一时间,是看自己代码是否写错,而不是直接去改错,代码没错,再看错误的情况,保证自己的代码不错的情况下,然后去排错!

相关推荐
IT_陈寒1 天前
Java 21虚拟线程实战:7个性能翻倍的异步重构案例与避坑指南
前端·人工智能·后端
不思念一个荒废的名字1 天前
【黑马JavaWeb+AI知识梳理】Web后端开发05-SpringAOP
后端
我爱学习好爱好爱1 天前
Springboot+OSHI+Vue+ECharts 全栈监控系统
vue.js·spring boot·echarts
BingoGo1 天前
PHP True Async 最近进展以及背后的争议
后端·php
程序员码歌1 天前
短思考第264天,每天复盘5分钟,胜过你盲目努力1整年(2)
前端·后端·ai编程
Victor3561 天前
Hibernate(3)Hibernate的优点是什么?
后端
Victor3561 天前
Hibernate(4)什么是Hibernate的持久化类?
后端
JaguarJack1 天前
PHP True Async 最近进展以及背后的争议
后端·php
想不明白的过度思考者1 天前
Spring Boot 配置文件深度解析
java·spring boot·后端
WanderInk1 天前
刷新后点赞全变 0?别急着怪 Redis,这八成是 Long 被 JavaScript 偷偷“改号”了(一次线上复盘)
后端