分享

mysql 关于日期的用法

 昵称584025 2010-01-17

 

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中即可。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多