sql计算日期差_sql中常用的日期计算语句

更新时间:2018-02-27    来源:生日祝福    手机版     字体:

【www.bbyears.com--生日祝福】

1.计算年龄

如果你有一个人的生日而需要计算这个人的年龄,将下列语句中@dateofbirth替换为生日即可

 代码如下

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")


关于mysql日期比较我们可以参考http://www.111cn.net/database/mysql/40632.htm

本文来源:http://www.bbyears.com/zhufuduanxin/39563.html

热门标签

更多>>

本类排行