欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL日期、時間、時間戳的獲取與計算過程

 更新時間:2025年05月24日 09:55:02   作者:壹業(yè)  
這篇文章主要介紹了MySQL日期、時間、時間戳的獲取與計算過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

MySQL日期處理

整體大綱

獲得時間

  • 獲得當(dāng)前日期+時間(date + time)函數(shù):now()
  • 獲得當(dāng)前日期+時間(date + time)函數(shù):sysdate()sysdate() 日期時間函數(shù),一般情況下很少用到。
  • MySQL 獲得當(dāng)前時間戳函數(shù):current_timestamp, current_timestamp()

查詢周數(shù)據(jù)

YEARWEEK()

  • 本周
SELECT id, CREATE_TIME
FROM user
WHERE YEARWEEK(date_format(MODIFY_TIME, ‘%Y-%m-%d')) = YEARWEEK(now());
  • 上周
SELECT id, CREATE_TIME
FROM user
WHERE YEARWEEK(date_format(CREATE_TIME, ‘%Y-%m-%d')) = YEARWEEK(now()) - 1;

查詢月數(shù)據(jù)

  • 當(dāng)前月份
SELECT id, CREATE_TIME
FROM user
where date_format(CREATE_TIME, ‘%Y-%m') = date_format(now(), ‘%Y-%m')
  • 距今六個月
SELECT id, CREATE_TIME
FROM user
where CREATE_TIME between date_sub(now(), interval 6 month) and now();
  • 上個月
SELECT id, CREATE_TIME
FROM user
where date_format(CREATE_TIME, ‘%Y-%m') = date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH), ‘%Y-%m')

時區(qū)(timezone)轉(zhuǎn)換函數(shù)

  • 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

時區(qū)轉(zhuǎn)換也可以通過 date_add, date_sub, timestampadd 來實(shí)現(xiàn)。

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

日期時間計算

為日期增加一個時間間隔: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

adddate(), addtime()函數(shù),可以用 date_add() 來替代。

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_sub()

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 |
±---------------------------------------------------------------+

date_sub() 日期時間函數(shù) 和 date_add() 用法一致

日期、時間相減函數(shù):datediff(date1,date2), timediff(time1,time2)

timediff(time1,time2) 函數(shù)的兩個參數(shù)類型必須相同。

MySQL datediff(date1,date2):兩個日期相減 date1 - date2,返回天數(shù)。

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

時間戳(timestamp)轉(zhuǎn)換、增、減函數(shù):

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() 函數(shù)類似于 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
timestamp(date) – date to timestamp
timestamp(dt,time) – dt + time
timestampadd(unit,interval,datetime_expr) –
timestampdiff(unit,datetime_expr1,datetime_expr2) –

后面的時間減去前面的時間

timestampdiff() 函數(shù)就比 datediff() 功能強(qiáng)多了,datediff() 只能計算兩個日期(date)之間相差的天數(shù)。

日期時間轉(zhuǎn)換

MySQL Date/Time to Str(日期/時間轉(zhuǎn)換為字符串)函數(shù):date_format(date,format), time_format(time,format)

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 |
±---------------------------------------------------+

date_format(date,format), time_format(time,format) 能夠把一個日期/時間轉(zhuǎn)換成各種各樣的字符串格式。它是 str_to_date(str,format) 函數(shù)的 一個逆轉(zhuǎn)換。

Str to Date (字符串轉(zhuǎn)換為日期)函數(shù):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) 轉(zhuǎn)換函數(shù),可以把一些雜亂無章的字符串轉(zhuǎn)換為日期格式。

(日期、天數(shù))轉(zhuǎn)換函數(shù):to_days(date), from_days(days)

select to_days(‘0000-00-00'); – 0
select to_days(‘2008-08-08'); – 733627

(時間、秒)轉(zhuǎn)換函數(shù):time_to_sec(time), sec_to_time(seconds)

select time_to_sec(‘01:00:05'); – 3605
select sec_to_time(3605); – ‘01:00:05'

拼湊日期、時間函數(shù):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'

(Unix 時間戳、日期)轉(zhuǎn)換函數(shù)

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'
  • unix_timestamp(),
  • unix_timestamp(date),
  • from_unixtime(unix_timestamp),
  • from_unixtime(unix_timestamp,format)

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql8.4版本mysql_native_password無法連接問題解決

    mysql8.4版本mysql_native_password無法連接問題解決

    用dbeaver可以直接連接,但是用NAVICAT連接后報錯,本文主要介紹了mysql8.4版本mysql_native_password無法連接問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • MySQL提示Truncated incorrect DOUBLE value解決方法

    MySQL提示Truncated incorrect DOUBLE value解決方法

    這篇文章給大家介紹了MySQL提示Truncated incorrect DOUBLE value報錯的四種解決方法,并通過代碼給大家介紹的非常詳細(xì),具有一定的參考價值,需要的朋友可以參考下
    2024-02-02
  • 基于Mysql存儲引擎的深入分析

    基于Mysql存儲引擎的深入分析

    本篇文章是對Mysql存儲引擎進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL與Oracle的語法區(qū)別詳細(xì)對比

    MySQL與Oracle的語法區(qū)別詳細(xì)對比

    Oracle和mysql的一些簡單命令對比在本文中將會涉及到很多的實(shí)例,感興趣的你不妨學(xué)習(xí)一下,就當(dāng)鞏固自己的知識了
    2013-03-03
  • JMeter壓測Mysql教程分享

    JMeter壓測Mysql教程分享

    文章介紹了如何使用JMeter進(jìn)行數(shù)據(jù)庫壓力測試的步驟,包括安裝JMeter、下載并配置MySQL JDBC驅(qū)動、設(shè)置測試計劃、添加JDBC連接配置元件、添加JDBC請求取樣器以及可選的監(jiān)聽器配置,最后,文章指導(dǎo)如何運(yùn)行測試并分析結(jié)果,以評估數(shù)據(jù)庫在不同壓力下的性能表現(xiàn)
    2024-11-11
  • Dbeaver連接MySQL數(shù)據(jù)庫及錯誤Connection?refusedconnect處理方法

    Dbeaver連接MySQL數(shù)據(jù)庫及錯誤Connection?refusedconnect處理方法

    這篇文章主要介紹了dbeaver連接MySQL數(shù)據(jù)庫及錯誤Connection?refusedconnect處理方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • mysql之觸發(fā)器使用

    mysql之觸發(fā)器使用

    這篇文章主要介紹了mysql之觸發(fā)器使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2017-09-09
  • SQL查詢表字段信息詳細(xì)圖文教程

    SQL查詢表字段信息詳細(xì)圖文教程

    最近工作用到SQL語句查詢表中所有字段的名稱,下面這篇文章主要給大家介紹了關(guān)于SQL查詢表字段信息的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • MySQL版oracle下scott用戶建表語句實(shí)例

    MySQL版oracle下scott用戶建表語句實(shí)例

    這篇文章主要給大家介紹了關(guān)于MySQL版oracle下scott用戶建表語句的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL允許遠(yuǎn)程登錄的操作實(shí)現(xiàn)

    MySQL允許遠(yuǎn)程登錄的操作實(shí)現(xiàn)

    本文主要介紹了MySQL允許遠(yuǎn)程登錄的操作實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-02-02

最新評論