java里怎么比较mysql存的时间和当前时间,大于当前时间7天,有详细代码吗

java里怎么比较mysql存的时间和当前时间,大于当前时间7天,有详细代码吗,第1张

sql中直接通过字符串比较就可以了
比如: xxx_time >= '2019-04-15 23:59:59'
如果是java的时间比较的方式就比较多了。
转成date类型比较是比较常见的方式,或long类型的时间戳方式,或这统一格式的字符串方式、

SELECT FROM order WHERE user_id=001 AND DATE_FORMAT(time,'%Y-%m-%d')="2014-10-11 "
或者
SELECT FROM order WHERE user_id=001 AND time >= 2014-10-11 AND time < 2014-10-12
如果表的记录较多时,推荐使用第二种的方法。

MYSQL日期比较
TO_DAYS(NOW())
-
TO_DAYS(date_col)
<=
30;
我们的date_col必须是日期时间格式,而不能是时间戳,
mysql>
SELECT
FROM_UNIXTIME(875996580);
->
'1997-10-04
22:23:00'
day(FROM_UNIXTIME(1277709862))这个返回的是某个时间戳到现在经过的天数
获取
日:day(FROM_UNIXTIME(add_time))
获取
月:month(FROM_UNIXTIME(add_time))
获取
年:year(FROM_UNIXTIME(add_time))
sql文里面获得时间戳后格式化为日,月,年:day(now()),month(now()),year(now())
其中add_time是字段名,存放格式为linux时间戳
mysql>
set
@a
=
unix_timestamp();
Query
OK,
0
rows
affected
(000
sec)
mysql>
select
@a;
+------------+
|
@a
|
+------------+
|
1154942084
|
+------------+
1
row
in
set
(000
sec)
mysql>
select
from_unixtime(@a);
+---------------------+
|
from_unixtime(@a)
|
+---------------------+
|
2006-08-07
17:14:44
|
+---------------------+
1
row
in
set
(000
sec)

select aname,avalue-bvalue as new from table a join table b on aname=bname where aday='2014-5-8' and bday='2014-5-7'


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13412543.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-31
下一篇 2023-07-31

发表评论

登录后才能评论

评论列表(0条)

保存