本篇文章为你整理了发现mybatisplus#Wrapper的一个小坑(mybatis-plus wrapper)的详细内容,包含有mybatis plus wrapper mybatis-plus wrapper mybatisplusupdatewrapper的用法 mybatisplusapi 发现mybatisplus#Wrapper的一个小坑,希望能帮助你了解 发现mybatisplus#Wrapper的一个小坑。
之所以提这个坑,是因为,今天下午,通过监控系统,发现我们系统生产能力突然下降,频繁报无法获取数据库连接。究其原因,竟然是因为mybatisplus的这个“坑”导致的。
public void getOne() {
LambdaQueryWrapper SbhPlatOrder wrappers = new LambdaQueryWrapper ();
wrappers.eq(SbhPlatOrder::getOrderId, 1L);
sbhPlatOrderManager.getOne(wrappers);
}
这里要说的是 eq 方法。该方法在mybatis-plus-core包里的Compare.java接口里,这个 eq 重载的方法签名如下:
// 在com.baomidou.mybatisplus.core.conditions.interfaces.Compare.java里
default Children eq(R column, Object val) {
return eq(true, column, val);
}
注意到这个 eq 方法的第二个参数的类型是 Object。
上面demo代码中,SbhPlatOrder#orderId 是String类型, 对应数据库里的字段的类型是 varchar。 而demo里给的参数值是个Long型数字。
这种情况下, mybatisplus——严格说,应该是mybatis——生成的sql日志如下,也就是说,sql语句是:SELECT * FROM sbh_plat_orderWHERE order_id = 1
16:40:44.287 DEBUG SbhPlatOrderMapper.selectOne:143 :== Preparing: SELECT * FROM sbh_plat_order WHERE order_id = ?
16:40:44.336 DEBUG SbhPlatOrderMapper.selectOne:143 :== Parameters: 1(Long)
but,但是,however,我们期望的SQL语句是:SELECT * FROM sbh_plat_order_20221026 WHERE order_id = 1
我的mybatisplus版本是 com.baomidou:mybatis-plus-boot-starter:jar:3.1.2, 希望高版本的mybatisplus可以解决这个类型转换问题。
之所以提这个坑,是因为,今天下午,通过监控系统,发现我们系统生产能力突然下降,频繁报无法获取数据库连接。
最终排查出来的原因,竟然是因为mybatisplus的这个“坑”导致的。 数据表 levy_payment_flow 的字段flow_no前不久 由bigint改成了varchar(32)。而程序里依然存在 wrappers.eq(SbhPlatOrder::getFlowNo, Long.parseLong(requestNo)); 这样的代码。赶上今天系统交易量大,就曝出问题了。levy_payment_flow 的字段flow_no 有唯一索引, 而 SELECT * FROM levy_payment_flow WHERE flow_no = 1642499617556336因为类型不匹配,是不会命中这个唯一索引的,导致全表扫描,SELECT * FROM levy_payment_flow WHERE flow_no = 1642499617556336才会。结果呢,问题sql执行耗时长达30s,修正程序改为后者那个SQL后,就是毫秒级了。
当看到一些不好的代码时,会发现我还算优秀;当看到优秀的代码时,也才意识到持续学习的重要!--buguge
本文来自,转载请注明原文链接:https:///buguge/p/16830176.html
以上就是发现mybatisplus#Wrapper的一个小坑(mybatis-plus wrapper)的详细内容,想要了解更多 发现mybatisplus#Wrapper的一个小坑的内容,请持续关注盛行IT软件开发工作室。
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。