• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL中常用的日期计算语句

MySql 海叔叔 4周前 (05-30) 5次浏览 已收录 0个评论

关键词
MySQL中常用的日期计算语句

摘要

在MySQL中有大量的函数来进行日期和时间相关的处理,比如UNIX_TIMESTAMP、date、DATE_FORMAT等相关函数,下面我把常用的几种MySQL日期操作函数总结一下,供大家参考。

MySQL中常用的日期计算语句

在MySQL中有大量的函数来进行日期和时间相关的处理,比如UNIX_TIMESTAMP、date、DATE_FORMAT等相关函数,下面我把常用的几种MySQL日期操作函数总结一下,供大家参考。

1.计算年龄

如果你有一个人的生日而需要计算这个人的年龄,[email protected]
SELECT DATE_FORMAT (FROM_DAYS (TO_DAYS (now ()) – TO_DAYS (@dateofbirth)), ‘%Y’) + 0;

2.计算两个日期的差值

计算两个日期的分,秒,小时和天数的差值,如果dt1和dt2的的格式是‘yyyy-mm-dd hh:mm:ss’,那么两个日期之间的秒数差值就是

UNIX_TIMESTAMP ( dt2 ) – UNIX_TIMESTAMP ( dt1 )

3.显示出现了N次的栏目的值

SELECT id
FROM tbl
GROUP BY id
HAVING COUNT (*) = N;

4.计算两个日期之间的工作日

计算两个日期之间的工作日的最简单方法是是一个含有d日期栏目和另一个标定了在已知年份中所有日期是否为休息日的栏目的日历表,然后下面的查询就是找到在Start和Stop两个日期之间所有的工作日
SELECT COUNT (*)
FROM calendar
WHERE d BETWEEN Start AND Stop
AND DAYOFWEEK (d) NOT IN (1,7)
AND holiday=0;

5.unix时间戳比较

Mysql内置函数:UNIX_TIMESTAMP()

若无参数调用,则默认返回一个 从 ‘1970-01-01 00:00:00’ 到当前时刻的秒数(无符号整数)。若用date 来调用 unix_timestamp(),它会返回从 ‘1970-01-01 00:00:00’ 到 date表示的时刻为止的秒数;date 可以是一个 date 字符串、一个 datetime字符串、一个 timestamp或一个当地时间的yymmdd 或yyymmdd格式的数字。

则sql语句可以这样写:
select id,title,content,addtime from tablename_tbl where UNIX_TIMESTAMP(addtime)>= UNIX_TIMESTAMP() – 10800 and UNIX_TIMESTAMP(addtime) <= UNIX_TIMESTAMP() //10800为3小时的秒数。 也可以这样写 select * from tb where c> date_format(‘2007-07-06′,’%Y%m%d’) and c <= date_format('2007-07-09','%Y%m%d'); select * from tb where c> date(‘2007-07-07’) and c< date('2007-07-09')


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址