搜尋
首頁資料庫mysql教程MySQL如何取得目前時間和時間戳

MySQL是最受歡迎的關聯式資料庫管理系統,在WEB應用方面MySQL是最好的RDBMS應用軟體之一。本次介紹中,會讓大家快速掌握MySQL取得目前時間和時間戳記的方法,輕鬆使用MySQL資料庫。

MySQL如何取得目前時間和時間戳

取得目前日期時間(date   time)函數:now()

MySQL> select now();
+———————+
| now() |
+———————+
| 2013-04-08 20:56:19 |
+———————+

除了 now() 函數能取得目前的日期時間外,MySQL 中還有下面的函數:

current_timestamp()
,current_timestamp,localtime()
,localtime
,localtimestamp — (v4.0.6)
,localtimestamp() — (v4.0.6)

這些日期時間函數,都等同於 now()。鑑於 now() 函數簡短易記,建議總是使用 now() 來取代上面列出的函數。

取得目前日期時間(date   time)函數:sysdate()

sysdate() 日期時間函數跟 now() 類似,不同之處在於:now() 在執行開始時值就得到了, sysdate() 在函數執行時動態得到值。看下面的例子就明白了:

mysql> select now(), sleep(3), now();
+———————+———-+———————+
| now() | sleep(3) | now() |
+———————+———-+———————+
| 2013-04-08 20:57:46 | 0 | 2013-04-08 20:57:46 |
+———————+———-+———————+
mysql> select sysdate(), sleep(3), sysdate();
+———————+———-+———————+
| sysdate() | sleep(3) | sysdate() |
+———————+———-+———————+
| 2013-04-08 20:58:47 | 0 | 2013-04-08 20:58:50 |
+———————+———-+———————+

可以看到,雖然中途 sleep 3 秒,但 now() 函數兩次的時間值是相同的; sysdate() 函數兩次得到的時間值相差3 秒。 MySQL Manual 中是這樣描述 sysdate() 的:Return the time at which the function executes。

sysdate() 日期時間函數,一般情況下很少用到。

獲得目前日期(date)函數:curdate()

mysql> select curdate();
+————+
| curdate() |
+————+
| 2013-04-08 |
+————+

其中,下面的兩個日期函數等同於 curdate():

current_date()
,current_date

取得目前時間(時間)函數:curtime()

mysql> select curtime();
+———–+
| curtime() |
+———–+
| 21:00:11 |
+———–+

其中,下列的兩個時間函數等同於 curtime(): 

current_time()
,current_time

#獲得目前 UTC 日期時間函數:utc_date(), utc_time(), utc_timestamp()

mysql> select utc_timestamp(), utc_date(), utc_time(),now();
+———————+————+————+———————+
| utc_timestamp() | utc_date() | utc_time() | now() |
+———————+————+————+———————+
| 2013-04-08 13:01:32 | 2013-04-08 | 13:01:32 |2013-04-08 21:01:32 |
+———————+————+————+———————+

因為我國位於東八時區,所以本地時間 = UTC 時間   8 小時。 UTC 時間在業務涉及多個國家和地區的時候,非常有用。

MySQL 日期時間 Extract(選取) 函數。

1. 選取日期時間的各個部分:日期、時間、年、季、月、日、小時、分鐘、秒、微秒

set @dt = ’2008-09-10 07:15:30.123456′;
select date(@dt); — 2008-09-10
select time(@dt); — 07:15:30.123456
select year(@dt); — 2008
select quarter(@dt); — 3
select month(@dt); — 9
select week(@dt); — 36
select day(@dt); — 10
select hour(@dt); — 7
select minute(@dt); — 15
select second(@dt); — 30
select microsecond(@dt); — 123456

2. MySQL Extract() 函數,可以在上面實現類似的功能:

et @dt = ’2008-09-10 07:15:30.123456′;
select extract(year from @dt); — 2008
select extract(quarter from @dt); — 3
select extract(month from @dt); — 9
select extract(week from @dt); — 36
select extract(day from @dt); — 10
select extract(hour from @dt); — 7
select extract(minute from @dt); — 15
select extract(second from @dt); — 30
select extract(microsecond from @dt); — 123456select extract(year_month from @dt); — 200809
select extract(day_hour from @dt); — 1007
select extract(day_minute from @dt); — 100715
select extract(day_second from @dt); — 10071530
select extract(day_microsecond from @dt); — 10071530123456
select extract(hour_minute from @dt); — 715
select extract(hour_second from @dt); — 71530
select extract(hour_microsecond from @dt); — 71530123456
select extract(minute_second from @dt); — 1530
select extract(minute_microsecond from @dt); — 1530123456
select extract(second_microsecond from @dt); — 30123456

MySQL Extract() 函數除了沒有date(),time() 的功能外,其他功能一應有全。並且還具有選取‘day_microsecond’ 等功能。注意這裡不是只選取 day 和 microsecond,而是從日期的 day 部分一直選取到 microsecond 部分。夠強悍的吧!

MySQL Extract() 函數唯一不好的地方在於:你需要多敲幾次鍵盤。

3. MySQL dayof… 函數:dayofweek(), dayofmonth(), dayofyear()

#分別傳回日期參數,一週、一月、一年中的位置。

set @dt = ’2008-08-08′;
select dayofweek(@dt); — 6
select dayofmonth(@dt); — 8
select dayofyear(@dt); — 221

日期 '2008-08-08′ 是一週的第 6 天(1 = Sunday, 2 = Monday, …, 7 = Saturday);一月中的第 8 天;一年中的第 221 天。

4. MySQL week… 函數:week(), weekofyear(), dayofweek(), weekday(), yearweek()

set @dt = ’2008-08-08′;
select week(@dt); — 31
select week(@dt,3); — 32
select weekofyear(@dt); — 32
select dayofweek(@dt); — 6
select weekday(@dt); — 4
select yearweek(@dt); — 200831
ek##My week#My week () 函數,可以有兩個參數,具體可看手冊。 weekofyear() 和 week() 一樣,都是計算「某天」是位於一年中的第幾週。 weekofyear(@dt) 等價於 week(@dt,3)。


MySQL weekday() 函數和 dayofweek() 類似,都是在一週中返回「某天」的位置。不同點在於參考的標準, weekday:(0 = Monday, 1 = Tuesday, …, 6 = Sunday); dayofweek:(1 = Sunday, 2 = #Monday, dayofweek:(1 = Sunday, 2 = #Monday, ., 7)” () 函數,傳回 year(2008)   week 位置(31)。

5. MySQL 返回星期和月份名稱函數:dayname(), monthname()

set @dt = ’2008-08-08′;
select dayname(@dt); — Friday
select monthname(@dt); — August
思考,如何回傳中文的名稱呢?


6. MySQL last_day() 函數:傳回月份中的最後一天。

select last_day(’2008-02-01′); — 2008-02-29
select last_day(’2008-08-08′); — 2008-08-31
MySQL last_day() 函數非常有用,例如我想要得到目前月份中有多少天,可以這樣來計算:
mysql> select now(), day(last_day(now())) as days;
+———————+——+
| now() | days |
+———————+——+
| 2013-04-08 21:03:14 | 30 |
+———————+——+

MySQL 日期時間計算函數


1. MySQL 增加日期時間間隔:date_add()

set @dt = now();
select date_add(@dt, interval 1 day); — add 1 day
select date_add(@dt, interval 1 hour); — add 1 hour
select date_add(@dt, interval 1 minute); — …
select date_add(@dt, interval 1 second);
select date_add(@dt, interval 1 microsecond);
select date_add(@dt, interval 1 week);
select date_add(@dt, interval 1 month);
select date_add(@dt, interval 1 quarter);
select date_add(@dt, interval 1 year);
select date_add(@dt, interval -1 day); — sub 1 day
MySQL adddate(), addtime()函數,可用 date_add() 來取代。以下是 date_add() 實作 addtime() 功能範例:
mysql> set @dt = ’2008-08-09 12:12:33′;
mysql>
mysql> select date_add(@dt, interval ’01:15:30′ hour_second);
+——————————————+
| date_add(@dt, interval ’01:15:30′ hour_second) |
+——————————————+
| 2008-08-09 13:28:03 |
+——————————————+
mysql> select date_add(@dt, interval ’1 01:15:30′ day_second);
+——————————————+
| date_add(@dt, interval ’1 01:15:30′ day_second) |
+——————————————+
| 2008-08-10 13:28:03 |
+——————————————+

date_add() 函数,分别为 @dt 增加了“1小时 15分 30秒” 和 “1天 1小时 15分 30秒”。建议:总是使用 date_add() 日期时间函数来替代 adddate(), addtime()。

2. MySQL 为日期减去一个时间间隔:date_sub()

mysql> select date_sub(’1998-01-01 00:00:00′, interval ’1 1:1:1′ day_second);
+——————————————+
| date_sub(’1998-01-01 00:00:00′, interval ’1 1:1:1′ day_second) |
+——————————————+
| 1997-12-30 22:58:59 |
+——————————————+

MySQL date_sub() 日期时间函数 和 date_add() 用法一致,不再赘述。另外,MySQL 中还有两个函数 subdate(), subtime(),建议,用 date_sub() 来替代。

3. MySQL 另类日期函数:period_add(P,N), period_diff(P1,P2)

函数参数“P” 的格式为“YYYYMM” 或者 “YYMM”,第二个参数“N” 表示增加或减去 N month(月)。

MySQL period_add(P,N):日期加/减去N月。

mysql> select period_add(200808,2), period_add(20080808,-2)
+——————————————+
| period_add(200808,2) | period_add(20080808,-2) |
+——————————————+
| 200810 | 20080806 |
+——————————————+
MySQL period_diff(P1,P2):日期 P1-P2,返回 N 个月。
mysql> select period_diff(200808, 200801);
+——————————————+
| period_diff(200808, 200801) |
+——————————————+
| 7 |
+——————————————+

在 MySQL 中,这两个日期函数,一般情况下很少用到。

4. MySQL 日期、时间相减函数:datediff(date1,date2), timediff(time1,time2)

MySQL datediff(date1,date2):两个日期相减 date1 – date2,返回天数。
select datediff(’2008-08-08′, ’2008-08-01′); — 7
select datediff(’2008-08-01′, ’2008-08-08′); — -7
MySQL timediff(time1,time2):两个日期相减 time1 – time2,返回 time 差值。
select timediff(’2008-08-08 08:08:08′, ’2008-08-08 00:00:00′); — 08:08:08
select timediff(’08:08:08′, ’00:00:00′); — 08:08:08

注意:timediff(time1,time2) 函数的两个参数类型必须相同。

MySQL 日期转换函数、时间转换函数

1. MySQL (时间、秒)转换函数:time_to_sec(time), sec_to_time(seconds)

select time_to_sec(’01:00:05′); — 3605
select sec_to_time(3605); — ’01:00:05′

2. MySQL (日期、天数)转换函数:to_days(date), from_days(days)

select to_days(’0000-00-00′); — 0
select to_days(’2008-08-08′); — 733627
select from_days(0); — ’0000-00-00′
select from_days(733627); — ’2008-08-08′

3. MySQL Str to Date (字符串转换为日期)函数:str_to_date(str, format)

select str_to_date(’08/09/2008′, ‘%m/%d/%Y’); — 2008-08-09
select str_to_date(’08/09/08′ , ‘%m/%d/%y’); — 2008-08-09
select str_to_date(’08.09.2008′, ‘%m.%d.%Y’); — 2008-08-09
select str_to_date(’08:09:30′, ‘%h:%i:%s’); — 08:09:30
select str_to_date(’08.09.2008 08:09:30′, ‘%m.%d.%Y %h:%i:%s’); — 2008-08-09 08:09:30

可以看到,str_to_date(str,format) 转换函数,可以把一些杂乱无章的字符串转换为日期格式。另外,它也可以转换为时间。“format” 可以参看 MySQL 手册。

4. MySQL Date/Time to Str(日期/时间转换为字符串)函数:date_format(date,format), time_format(time,format)

mysql> select date_format(’2008-08-08 22:23:00′, ‘%W %M %Y’);
+——————————————+
| date_format(’2008-08-08 22:23:00′, ‘%W %M %Y’) |
+——————————————+
| Friday August 2008 |
+——————————————+
mysql> select date_format(’2008-08-08 22:23:01′, ‘%Y%m%d%H%i%s’);
+——————————————+
| date_format(’2008-08-08 22:23:01′, ‘%Y%m%d%H%i%s’) |
+——————————————+
| 20080808222301 |
+——————————————+
mysql> select time_format(’22:23:01′, ‘%H.%i.%s’);
+——————————————+
| time_format(’22:23:01′, ‘%H.%i.%s’) |
+——————————————+
| 22.23.01 |
+——————————————+

MySQL 日期、时间转换函数:date_format(date,format), time_format(time,format) 能够把一个日期/时间转换成各种各样的字符串格式。它是 str_to_date(str,format) 函数的 一个逆转换。

5. MySQL 获得国家地区时间格式函数:get_format()

MySQL get_format() 语法:

get_format(date|time|datetime, ‘eur’|’usa’|’jis’|’iso’|’internal’

MySQL get_format() 用法的全部示例:

select get_format(date,’usa’) ; — ‘%m.%d.%Y’
select get_format(date,’jis’) ; — ‘%Y-%m-%d’
select get_format(date,’iso’) ; — ‘%Y-%m-%d’
select get_format(date,’eur’) ; — ‘%d.%m.%Y’
select get_format(date,’internal’) ; — ‘%Y%m%d’
select get_format(datetime,’usa’) ; — ‘%Y-%m-%d %H.%i.%s’
select get_format(datetime,’jis’) ; — ‘%Y-%m-%d %H:%i:%s’
select get_format(datetime,’iso’) ; — ‘%Y-%m-%d %H:%i:%s’
select get_format(datetime,’eur’) ; — ‘%Y-%m-%d %H.%i.%s’
select get_format(datetime,’internal’) ; — ‘%Y%m%d%H%i%s’
select get_format(time,’usa’) ; — ‘%h:%i:%s %p’
select get_format(time,’jis’) ; — ‘%H:%i:%s’
select get_format(time,’iso’) ; — ‘%H:%i:%s’
select get_format(time,’eur’) ; — ‘%H.%i.%s’
select get_format(time,’internal’) ; — ‘%H%i%s’

MySQL get_format() 函数在实际中用到机会的比较少。

6. MySQL 拼凑日期、时间函数:makdedate(year,dayofyear), maketime(hour,minute,second)

select makedate(2001,31); — ’2001-01-31′
select makedate(2001,32); — ’2001-02-01′
select maketime(12,15,30); — ’12:15:30′

MySQL 时间戳(Timestamp)函数

1. MySQL 获得当前时间戳函数:current_timestamp, current_timestamp()

mysql> select current_timestamp, current_timestamp();
+——————————————+
| current_timestamp | current_timestamp() |
+——————————————+
| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |
+——————————————+

2. MySQL (Unix 时间戳、日期)转换函数:

unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)

下面是示例:

select unix_timestamp(); — 1218290027
select unix_timestamp(’2008-08-08′); — 1218124800
select unix_timestamp(’2008-08-08 12:30:00′); — 1218169800
select from_unixtime(1218290027); — ’2008-08-09 21:53:47′
select from_unixtime(1218124800); — ’2008-08-08 00:00:00′
select from_unixtime(1218169800); — ’2008-08-08 12:30:00′
select from_unixtime(1218169800, ‘%Y %D %M %h:%i:%s %x’); — ’2008 8th August 12:30:00 2008′

3. MySQL 时间戳(timestamp)转换、增、减函数:

timestamp(date) — date to timestamp
timestamp(dt,time) — dt + time
timestampadd(unit,interval,datetime_expr) –
timestampdiff(unit,datetime_expr1,datetime_expr2) –

请看示例部分:

select timestamp(’2008-08-08′); — 2008-08-08 00:00:00
select timestamp(’2008-08-08 08:00:00′, ’01:01:01′); — 2008-08-08 09:01:01
select timestamp(’2008-08-08 08:00:00′, ’10 01:01:01′); — 2008-08-18 09:01:01
select timestampadd(day, 1, ’2008-08-08 08:00:00′); — 2008-08-09 08:00:00
select date_add(’2008-08-08 08:00:00′, interval 1 day); — 2008-08-09 08:00:00
MySQL timestampadd() 函数类似于 date_add()。
select timestampdiff(year,’2002-05-01′,’2001-01-01′); — -1
select timestampdiff(day ,’2002-05-01′,’2001-01-01′); — -485
select timestampdiff(hour,’2008-08-08 12:00:00′,’2008-08-08 00:00:00′); — -12
select datediff(’2008-08-08 12:00:00′, ’2008-08-01 00:00:00′); — 7
MySQL timestampdiff() 函数就比 datediff() 功能强多了,datediff() 只能计算两个日期(date)之间相差的天数。

MySQL timestampdiff() 函数就比 datediff() 功能强多了,datediff() 只能计算两个日期(date)之间相差的天数。

MySQL 时区(timezone)转换函数convert_tz(dt,from_tz,to_tz)

select convert_tz(’2008-08-08 12:00:00′, ‘+08:00′, ‘+00:00′); — 2008-08-08 04:00:00
时区转换也可以通过 date_add, date_sub, timestampadd 来实现。
select date_add(’2008-08-08 12:00:00′, interval -8 hour); — 2008-08-08 04:00:00
select date_sub(’2008-08-08 12:00:00′, interval 8 hour); — 2008-08-08 04:00:00
select timestampadd(hour, -8, ’2008-08-08 12:00:00′); — 2008-08-08 04:00:00

相关学习推荐:mysql教程(视频)

以上是MySQL如何取得目前時間和時間戳的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:CSDN。如有侵權,請聯絡admin@php.cn刪除
MySQL和其他SQL方言之間的語法有什麼區別?MySQL和其他SQL方言之間的語法有什麼區別?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit,自動啟動,弦樂範圍,子征服和表面上分析。 1)MySqluessLipslimit,whilesqlserverusestopopandoraclesrontersrontsrontsrontsronnum.2)

什麼是mysql分區?什麼是mysql分區?Apr 27, 2025 am 12:23 AM

MySQL分區能提升性能和簡化維護。 1)通過按特定標準(如日期範圍)將大表分成小塊,2)物理上將數據分成獨立文件,3)查詢時MySQL可專注於相關分區,4)查詢優化器可跳過不相關分區,5)選擇合適的分區策略並定期維護是關鍵。

您如何在MySQL中授予和撤銷特權?您如何在MySQL中授予和撤銷特權?Apr 27, 2025 am 12:21 AM

在MySQL中,如何授予和撤銷權限? 1.使用GRANT語句授予權限,如GRANTALLPRIVILEGESONdatabase_name.TO'username'@'host';2.使用REVOKE語句撤銷權限,如REVOKEALLPRIVILEGESONdatabase_name.FROM'username'@'host',確保及時溝通權限變更。

說明InnoDB和Myisam存儲引擎之間的差異。說明InnoDB和Myisam存儲引擎之間的差異。Apr 27, 2025 am 12:20 AM

InnoDB適合需要事務支持和高並發性的應用,MyISAM適合讀多寫少的應用。 1.InnoDB支持事務和行級鎖,適用於電商和銀行系統。 2.MyISAM提供快速讀取和索引,適合博客和內容管理系統。

MySQL中有哪些不同類型的連接?MySQL中有哪些不同類型的連接?Apr 27, 2025 am 12:13 AM

MySQL中有四種主要的JOIN類型:INNERJOIN、LEFTJOIN、RIGHTJOIN和FULLOUTERJOIN。 1.INNERJOIN返回兩個表中符合JOIN條件的所有行。 2.LEFTJOIN返回左表中的所有行,即使右表中沒有匹配的行。 3.RIGHTJOIN與LEFTJOIN相反,返回右表中的所有行。 4.FULLOUTERJOIN返回兩個表中所有符合或不符合JOIN條件的行。

MySQL中有哪些不同的存儲引擎?MySQL中有哪些不同的存儲引擎?Apr 26, 2025 am 12:27 AM

mysqloffersvariousStorageengines,每個suitedfordferentusecases:1)InnodBisidealForapplicationsNeedingingAcidComplianCeanDhighConcurncurnency,supportingtransactionsancions and foreignkeys.2)myisamisbestforread-Heavy-Heavywyworks,lackingtransactionsactionsacupport.3)記憶

MySQL中有哪些常見的安全漏洞?MySQL中有哪些常見的安全漏洞?Apr 26, 2025 am 12:27 AM

MySQL中常見的安全漏洞包括SQL注入、弱密碼、權限配置不當和未更新的軟件。 1.SQL注入可以通過使用預處理語句防止。 2.弱密碼可以通過強制使用強密碼策略避免。 3.權限配置不當可以通過定期審查和調整用戶權限解決。 4.未更新的軟件可以通過定期檢查和更新MySQL版本來修補。

您如何確定MySQL中的慢速查詢?您如何確定MySQL中的慢速查詢?Apr 26, 2025 am 12:15 AM

在MySQL中識別慢查詢可以通過啟用慢查詢日誌並設置閾值來實現。 1.啟用慢查詢日誌並設置閾值。 2.查看和分析慢查詢日誌文件,使用工具如mysqldumpslow或pt-query-digest進行深入分析。 3.優化慢查詢可以通過索引優化、查詢重寫和避免使用SELECT*來實現。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。