程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> sql中常用的日期計算語句

sql中常用的日期計算語句

編輯:MySQL綜合教程

在mysql中對於日期計算有大量的函數,如有DATE_FORMAT、UNIX_TIMESTAMP、date等等相關的日期函數,下面我把常用的幾種mysql日期操作函數總結一下,歡迎各位同學參考。

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.bKjia.c0m/database/mysql/40632.htm

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved