亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL日期、時(shí)間、時(shí)間戳的獲取與計(jì)算過(guò)程

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

MySQL日期處理

整體大綱

獲得時(shí)間

  • 獲得當(dāng)前日期+時(shí)間(date + time)函數(shù):now()
  • 獲得當(dāng)前日期+時(shí)間(date + time)函數(shù):sysdate()sysdate() 日期時(shí)間函數(shù),一般情況下很少用到。
  • MySQL 獲得當(dāng)前時(shí)間戳函數(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;

查詢?cè)聰?shù)據(jù)

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

時(shí)區(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

時(shí)區(qū)轉(zhuǎn)換也可以通過(guò) date_add, date_sub, timestampadd 來(lái)實(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

日期時(shí)間計(jì)算

為日期增加一個(gè)時(shí)間間隔: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() 來(lái)替代。

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

為日期減去一個(gè)時(shí)間間隔: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í)間函數(shù) 和 date_add() 用法一致

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

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

MySQL datediff(date1,date2):兩個(gè)日期相減 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):兩個(gè)日期相減 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

時(shí)間戳(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) –

后面的時(shí)間減去前面的時(shí)間

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

日期時(shí)間轉(zhuǎn)換

MySQL Date/Time to Str(日期/時(shí)間轉(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) 能夠把一個(gè)日期/時(shí)間轉(zhuǎn)換成各種各樣的字符串格式。它是 str_to_date(str,format) 函數(shù)的 一個(gè)逆轉(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ù),可以把一些雜亂無(wú)章的字符串轉(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

(時(shí)間、秒)轉(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í)間函數(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 時(shí)間戳、日期)轉(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é)

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

相關(guān)文章

  • mysql8.4版本mysql_native_password無(wú)法連接問(wèn)題解決

    mysql8.4版本mysql_native_password無(wú)法連接問(wèn)題解決

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

    MySQL提示Truncated incorrect DOUBLE value解決方法

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

    基于Mysql存儲(chǔ)引擎的深入分析

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

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

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

    JMeter壓測(cè)Mysql教程分享

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

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

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

    mysql之觸發(fā)器使用

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

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

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

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

    這篇文章主要給大家介紹了關(guān)于MySQL版oracle下scott用戶建表語(yǔ)句的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(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),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-02-02

最新評(píng)論