MySQL、MybatisPlus中的坑啊啊啊啊啊

时间:2024-12-21 07:02:02

今天遇到一个十分坑人的一个问题

看上去如此简单的一个mybatisplus的运用 但是!!!一直卡在这一直无法执行到下一步

于是我开始一步步排查:

一、排查数据库监控

 

发现这个Query的sql一直卡在那但是又没有选中db

于是

show full processlist; 

我kill了好几次也不行 简直崩溃了都

但是也了解了不少这个监控的一些学习内容

MySQL中 show processlist 和 show full processlist 命令详解
processlist 命令的输出结果显示了有哪些线程在运行,不仅可以查看当前所有的连接数,还可以查看当前的连接状态帮助识别出有问题的查询语句等。

如果是 root 帐号,能看到所有用户的当前连接。如果是其他普通帐号,则只能看到自己占用的连接。show processlist 只能列出当前100条。如果想全部列出,可以使用 SHOW FULL PROCESSLIST命令 。

show full processlist 返回的结果是实时变化的,是对mysql链接执行的现场快照,所以用来处理突发事件非常有用。


参数
id            #ID标识,要kill一个语句的时候很有用
use            #当前连接用户
host        #显示这个连接从哪个ip的哪个端口上发出
db            #数据库名
command        #连接状态,一般是休眠(sleep),查询(query),连接(connect)
time        #连接持续时间,单位是秒
state        #显示当前sql语句的状态
info        #显示这个sql语句

 

二、排查代码

发现实体类中没有@TableName()注解于是思考是不是这个问题但是之前都没啥问题啊

最终发现数据库的字段没有 同步更新 导致字段和实体类的数量不一致 加上果然就好了

 

在 MyBatis-Plus 中,如果实体类没有添加 @TableName 注解,且实体类字段与数据库表字段不一致,可能会导致以下问题:

  • 性能影响:
  • MyBatis-Plus 会尝试自动映射表名,这个过程会消耗一些时间
  • 字段不一致时会进行大量的反射操作来尝试匹配字段
  • 在第一次执行时会特别明显,因为需要进行表信息的初始化缓存