在mysql中,可以使用CURDATE()和CURRENT_DATE()函數(shù)來獲取當(dāng)前日期,可以將當(dāng)前日期按照“YYYY-MM-DD”或“YYYYMMDD”格式的值返回,具體格式根據(jù)函數(shù)用在字符串或數(shù)字語境中而定。
(推薦教程:mysql視頻教程)
MySQL 中 CURDATE() 和 CURRENT_DATE()
MySQL 中 CURDATE() 和 CURRENT_DATE() 函數(shù)的作用相同,將當(dāng)前日期按照“YYYY-MM-DD”或“YYYYMMDD”格式的值返回,具體格式根據(jù)函數(shù)用在字符串或數(shù)字語境中而定。
【實(shí)例1】使用日期函數(shù) CURDATE 和 CURRENT_DATE 獲取系統(tǒng)當(dāng)前日期,輸入的 SQL 語句和執(zhí)行結(jié)果如下所示。
mysql> SELECT CURDATE(),CURRENT_DATE(),CURRENT_DATE()+0; +------------+----------------+------------------+ | CURDATE() | CURRENT_DATE() | CURRENT_DATE()+0 | +------------+----------------+------------------+ | 2020-10-13 | 2020-10-13 | 20201013 | +------------+----------------+------------------+ 1 row in set (0.03 sec)
由運(yùn)行結(jié)果可以看到,兩個(gè)函數(shù)的作用相同,返回了相同的系統(tǒng)當(dāng)前日期,“CURDATE()+0”將當(dāng)前日期值轉(zhuǎn)換為數(shù)值型的。
MySQL中 NOW() 和 SYSDATE()
MySQL中 NOW() 和 SYSDATE() 函數(shù)的作用相同,都是返回當(dāng)前日期和時(shí)間值,格式為“YYYY-MM-DD HH:MM:SS”或“YYYYMMDDHHMMSS”,具體格式根據(jù)函數(shù)用在字符串或數(shù)字語境中而定。
【實(shí)例2】使用日期時(shí)間函數(shù) NOW 和 SYSDATE 獲取當(dāng)前系統(tǒng)的日期和時(shí)間,輸入的 SQL 語句和執(zhí)行結(jié)果如下所示。
mysql> SELECT NOW(),SYSDATE(); +---------------------+---------------------+ | NOW() | SYSDATE() | +---------------------+---------------------+ | 2017-04-01 19:36:52 | 2017-04-01 19:36:52 | +---------------------+---------------------+ 1 row in set (0.04 sec)
由運(yùn)行結(jié)果可以看到,NOW 函數(shù)和 SYSDATE 函數(shù)返回的結(jié)果是相同的。
雖然在 MySQL 中 NOW() 和 SYSDATE() 都表示當(dāng)前時(shí)間,但是 NOW() 取的是語句開始執(zhí)行的時(shí)間,而 SYSDATE() 取的是語句執(zhí)行過程中動(dòng)態(tài)的實(shí)時(shí)時(shí)間。
【實(shí)例3】先查詢了 NOW() 和 SYSDATE(),然后 sleep 了 3 秒,再查詢 NOW() 和 SYSDATE(),結(jié)果如下:
mysql> select now(),sysdate(),sleep(3),now(),sysdate(); +-----------------------+------------------------+-------------+-----------------------+---------------------+ | now() | sysdate() | sleep(3) | now() | sysdate() | +-----------------------+------------------------+-------------+------------------- ---+---------------------+ | 2019-02-27 10:59:39 | 2019-02-27 10:59:39 | 0 | 2019-02-27 10:59:39 | 2019-02-27 10:59:42 | +-----------------------+------------------------+-------------+-----------------------+---------------------+ 1 row in set (3.00 sec)
由運(yùn)行結(jié)果可以看出,NOW() 函數(shù)始終獲取的是 SQL 語句開始執(zhí)行的時(shí)間,而 SYSDATE() 函數(shù)則是動(dòng)態(tài)獲取的實(shí)時(shí)時(shí)間。