mysql 关于日期的用法

mysql 中需要日期的加减,可以使用函数 加"DATE_ADD",减"DATE_SUB "
例如:
DATE_ADD(CURTIME(),INTERVAL 1 DAY) 当前时间加一天
DATE_SUB(CURTIME(),INTERVAL 1 DAY) 当前时间减一天

如果你从 YYYY-MM-DD HH:MM:SS 到 YYYY-MM-DD
可以使用 DATE(CURTIME())
例如 你想统计 "输入时间" 的那一整天 的数据,就需要使用它(如果用sql),因为输入的时间是 YYYY-MM-DD HH:MM:SS 格式的,你需要的是 YYYY-MM-DD 00:00:00 到 YYYY-MM-DD +1 00:00:00 这段时间的数据。

select count(*) from table as vo where DATE(DATE_ADD([color=red]:date[/color],INTERVAL 1 DAY)) > createTime and DATE([color=red]:date[/color]) < createTime

红色是输入的时间参数,这段sql 反映的是 table表中 在"输入的时间"当天创建的数据的总数。
:date = 2009-04-09 19:25:30

table表中
id name createTime
0 a 2009-04-08 15:25:30
[color=blue]1 b 2009-04-09 16:25:30
2 c 2009-04-09 17:25:30
3 d 2009-04-09 18:25:30[/color]

经过 DATE_ADD(:date,INTERVAL 1 DAY) 运算得到是 2009-04-10 19:25:30
再经过 [color=red]DATE( [/color]DATE_ADD(:date,INTERVAL 1 DAY)[color=red] )[/color] 运算得到的是 2009-04-10 00:00:00

所以 sql 中是求 createTime 在 2009-04-10 00:00:00 与 2009-04-09 00:00:00 之间的数据总数

这是在sql中实现日期的加减,也可以用java方法来实现,然后作为参数输入sql中即可。
请见下一个文章 [color=red]java对日期的运算方法[/color]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值