关于datetime以及timestamp在SQL server中出现的问题

在使用MyBatis进行SQLServer数据库查询时,若涉及包含毫秒级精度的时间字段,需注意MyBatis可能忽略毫秒部分,导致查询结果不精确。本文解析问题原因,并提供解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

提示:项目持久化采用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()实际上包含了毫秒数,所以要记得处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值