mybatis打印sql_一不小心,发现了Mybatis的一个坑

mybatis查询无结果, 数据库运行相同sql查询出结果, 如下

这是数据库记录

5fd5bddfbbc2aa1e547f8722258104c3.png

这是mybatis查询出的结果, 记录条数0

06234e8f92f64dab242f3443dc9b6ad6.png

这是直接将控制台一模一样的sql查询语句放到Navicat执行的结果, 记录条数1

75eaafc013eb90f0ae068e16d96cce55.png

解决办法

将 where条件后的 username='${username}'和 andpassword='${password}'置为同一行

d0f0bf6cfa2d959cfa19017bc8f92e59.png
a2284c6c7c30ea474114c9d6a89a5dc2.png

可以看到, 查询结果一致

70a0a46f8704dd646a3cf9c0e286e485.png

异常分析

  1. 很多小伙伴都遇到过类似问题, 很懵逼, 难不成mybatis bug? 没, 原因可能千万种, 但根本原因基本上就一个, 那就是实际查询语句与我们看到的sql不一致, 即, sql写的有问题
  2. 再来分析一下上面这个问题, 看似xml sql没有问题, 控制台打印的sql也没问题, 但放到数据库执行结果就不一致了, 因为, xml sql两个条件换行了, mybatis实际执行的sql是这样的:
807f7ae2d6a4534915e6b71e6bd4e4e5.png

并不是控制台打印的sql:

b24ca3368c8113063a7807db0a7ee995.png

查询结果自然不一致

总结

本文只是提供一种解决类似问题的思路, 出错原因可能不一样, 但问题关键就是实际执行的sql不一致, 才会导致mybatis和mysql查询结果不一致, 所以, 仔细点, 检查sql

另, 本文是为了测试sql注入, 所以用的 ${username}, 实际应该使用 #{}

我自己是一名从事了多年开发的Java老程序员,辞职目前在做自己的Java私人定制课程,今年年初我花了一个月整理了一份最适合2019年学习的Java学习干货,从最基础的JavaSE到Spring各种框架都有整理,送给每一位Java小伙伴,想要获取的可以关注我的头条号并在后台私信我:Java,即可免费获取。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值