mysql 关于日期的用法

来源:百度文库 编辑:神马文学网 时间:2024/06/05 07:54:43

 

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(:date,INTERVAL 1 DAY)) > createTime and  DATE(:date) < createTime

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

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

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

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

这是在sql中实现日期的加减,也可以用java方法来实现,然后作为参数输入sql中即可。