当前位置:   article > 正文

mybatis Date类型和Timestamp隐式转换问题,导致sql执行变慢。_mybatis date timestamp

mybatis date timestamp

mybatis Date类型和Timestamp隐式转换问题,导致sql执行变慢。

如果JAVA中字段属性为DATE类型,并且数据库中对应的类型也是date类型,在进行映射时,mybatis会默认将JAVA里的DATE类型映射为数据库中的Timestamp类型。

例如:

select * from order where create_date = #{createDate}
  • 1

这里的createDate在JAVA中为DATE类型,create_date在数据库中为date类型,但是mybatis在做映射时,会将createDate的类型改为Timestamp,导致where条件中两边类型不一致,oracle数据库会将date类型转换为Timestamp,实际执行sql为:

select * from order where to_timestamp(create_date) = #{createDate}
  • 1

这样的话,该字段不会走索引。

修改方法一

select * from order where create_date = cast(#{createDate} as date)
  • 1

修改方式二
将createDate在java代码中处理为日期字符串类型,再传入

select * from order where create_date = to_date(#{createDateStr},'yyyy-MM-dd')
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/870430
推荐阅读
相关标签
  

闽ICP备14008679号