项目场景:
提示:项目持久化采用mybatis,数据库使用SQL server:
问题描述:
数据库存在用户表users,有一个字段last_login_time,现在有一个需求,查询在2020-08-27 15:38:10.433后登录的用户(数据库中不存在满足要求的数据),然而
使用mybatis 的example查询语句,窗口打印的sql语句会显示total:1
解决方案:
Debug之后发现,虽然mybatis使用?的方式放入了对应的参数,但实际上,mybatis忽略了其中的毫秒数,433,实际上的查询条件为last_login_time > ‘2020-08-27 15:38:10’,所以会出现查询到本身的数据,所以出现了total : 1。实际上还是因为编写代码的时候经常使用new Date()方式生成时间,new Date()实际上包含了毫秒数,所以要记得处理。