java为什么不适合mysql_为什么我不能将java.util.Date与mysql日期进行比较?

我有一个奇怪的情况:

我正在使用jpa / hibernate从mySql数据库表中获取行,其中日期列大于或等于我发送的日期(删除了不相关的代码):

SELECT sp.* FROM spaceproduct sp where sp.enddate is null or sp.enddate >= :endDate)

在我的代码中,我基本上是这样做的:

q.setParameter("endDate", new java.util.Date());

现在,我的问题是数据库中的日期是同一日期.即“今天”,它不会被捡起.我认为这是因为它以某种方式还将java.util.date的时间部分与数据库中的内容进行了比较(db值仅是“ 2011-10-28”,而java.util日期是2011-10-28T13:36 :43.130 0200)

但是,如果我将我设置的date参数更改为java.sql.Date(),它将起作用!

现在,假设mySql DB列是Date,而不是DateTime,这不是bug吗?即使我发送了java.util.date,它也不应该只比较日期部分,因为我的DB列是日期吗?

编辑:我尝试使用util-date并将其转换为sql-date.这实际上也不起作用:

java.util.Date utilDate = new java.util.Date();

java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());

q.setParameter("endDate", sqlDate);

因此,从我可以看到的角度来看,对于sql-dates,我也必须将时间部分设置为0,除非我使用了不建议使用的“ year-month-date”构造函数…

解决方法:

您可以使用System.currentTimeMillis()而不是创建util Date来延长该时间.我希望您编辑的代码能够正常工作,但如果没有,您别无选择,只能以某种方式丢弃小时/分钟/秒/毫秒,例如执行System.currentTimeMillis()%24 * 60 * 60 * 1000 (当然,最好将其存储在一个常量中,但这很重要).或者,您可以只使用Joda.

标签:jpa,hibernate,java,mysql,date

来源: https://codeday.me/bug/20191102/1988526.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值