好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 一篇文章搞定Mysql日期時間函數(shù)

一篇文章搞定Mysql日期時間函數(shù)

熱門標(biāo)簽:云南語音外呼系統(tǒng)平臺 北京人工外呼系統(tǒng)價錢 天智外呼系統(tǒng) 房產(chǎn)智能外呼系統(tǒng)品牌 常州電銷外呼系統(tǒng)一般多少錢 地圖標(biāo)注被騙三百怎么辦 福州呼叫中心外呼系統(tǒng)哪家好 沃克斯電梯外呼線路圖 400電話鄭州申請

前言

日期和時間函數(shù)部分也是我們?nèi)粘9ぷ髦惺褂妙l率比較高的一部分。這一篇我們主要講講Mysql里面的日期時間相關(guān)的函數(shù),不同數(shù)據(jù)庫之間基本相同,只會有個別函數(shù)的差異。大家掌握一個數(shù)據(jù)庫的,其他的遇到不會的,直接查就可以了。

1.獲取當(dāng)前時刻時間

    1.1返回當(dāng)前時刻的日期和時間

    1.2獲取當(dāng)前時刻的日期

    1.3獲取當(dāng)前時刻的時間

    1.4獲取當(dāng)前時刻的周數(shù)

2.日期時間格式轉(zhuǎn)換

3.日期時間運算

    3.1向后偏移時間

    3.2向前偏移時間

    3.3兩日期做差

文章較長,建議先收藏,慢慢讀。

1.獲取當(dāng)前時刻時間

獲取當(dāng)前時刻的時間就是獲取程序運行的那一刻與時間相關(guān)的數(shù)據(jù),比如年月日、時分秒等信息。

1.1返回當(dāng)前時刻的日期和時間

返回當(dāng)前時刻的日期和時間在ESql中用的是now()函數(shù),直接在select后面寫上now()函數(shù)即可,具體代碼如下:

select now()

運行上面代碼就會得到你程序運行這一刻所處的年月日、時分秒的信息,比如:2019-12-25 22:47:37。

1.2獲取當(dāng)前時刻的日期

前面的now()函數(shù)獲取的是當(dāng)前時刻的日期和時間,我們有的時候可能只需要當(dāng)前時刻的日期部分,并不需要時間部分,這個時候在在Sql中將now()函數(shù)換成curdate()函數(shù),就是獲取當(dāng)前時刻的日期部分,具體代碼如下:

select curdate()

通過運行上面的代碼,我們得到了當(dāng)前時刻的日期部分:2019-12-25

curdate()函數(shù)是直接獲取當(dāng)前時刻的日期部分,我們也可以先通過now()函數(shù)獲取當(dāng)前時刻的日期時間,然后再通過date()函數(shù)將日期時間轉(zhuǎn)化為日期部分,具體代碼如下:

select date(now())

通過運行上面的代碼,會得到與curdate()函數(shù)相同的結(jié)果。

我們也可以只獲取日期中的年,使用的是year()函數(shù),具體代碼如下:

select year(now())

通過運行上面的代碼,最后得到的結(jié)果為2019。

我們也可以只獲取日期中的月,使用的是month()函數(shù),具體代碼如下:

select month(now())

通過運行上面的代碼,最后得到的結(jié)果為12。

我們也可以只獲取日期中的日,使用的是day()函數(shù),具體代碼如下:

select day(now())

通過運行上面的代碼,最后得到的結(jié)果為25。

1.3獲取當(dāng)前時刻的時間

我們除了有只獲取當(dāng)前時刻的日期的需求外,我們還有只獲取當(dāng)前時刻的時間需求。如果我們想只獲取當(dāng)前時刻的時間,只需要把只獲取當(dāng)前時刻日期的curdate()函數(shù)換成curtime()函數(shù)即可,具體代碼如下:

select curtime()

通過運行上面的代碼,就可以獲取當(dāng)前時刻的時間部分:22:47:37。

我們也可以先通過now()函數(shù)獲取當(dāng)前時刻的日期時間,然后再通過time()函數(shù)將日期時間轉(zhuǎn)化為時間部分,具體代碼如下:

select time(now())

通過運行上面的代碼,會得到與curdate()函數(shù)相同的結(jié)果。

我們也可以只獲取時間中的小時,使用的是hour()函數(shù),具體代碼如下:

select hour(now())

通過運行上面的代碼,最后得到的結(jié)果為22。

我們也可以只獲取時間中的分鐘,使用的是minute()函數(shù),具體代碼如下:

select minute(now())

通過運行上面的代碼,最后得到的結(jié)果為47。

我們也可以只獲取時間中的秒,使用的是second()函數(shù),具體代碼如下:

select second(now())

通過運行上面的代碼,最后得到的結(jié)果為37。

1.4獲取當(dāng)前時刻的周數(shù)

上面我們講了如何獲取當(dāng)前時刻的日期時間、日期、時間這三部分。這一節(jié)我們再看下如何獲取當(dāng)前時刻所屬的周數(shù)。我們一般會將全年分為52周(365天/7),有的時候也可能是53周,如果我們想看下當(dāng)前時刻是全年中的第幾周,可以使用weekofyear()函數(shù),具體代碼如下:

select weekofyear(now())

通過運行上面的代碼,最后得到的結(jié)果為52。

除了獲取當(dāng)前是全年的第幾周以外,我們還需要獲取當(dāng)天是一周內(nèi)的周幾。在Sql中使用的dayofweek()函數(shù),具體代碼如下:

select dayofweek(now())

通過運行上面的代碼,最后得到結(jié)果為5,2019年12月25日應(yīng)該是周四哈,為什么結(jié)果是5呢,這是因為該函數(shù)中一周是從周日開始的,也就是周日對應(yīng)的是1,周一對應(yīng)的是2,以此類推,所以周四對應(yīng)的是5。

2.日期時間格式轉(zhuǎn)換

我們知道同一個日期時間會有多種不同的表示方式,有的時候需要在不同格式之間相互轉(zhuǎn)換。在Sql中我們用的是date_format()函數(shù),date_format函數(shù)格式如下:

date_format(datetime,format)

datetime表示要被轉(zhuǎn)換的具體的日期時間,format表示要轉(zhuǎn)換成的格式,可選的格式如下:

主題

格式

描述

%Y

4位數(shù)的年

%b

月份對應(yīng)的英文縮寫

%M

月份對應(yīng)的英文全稱

%m

01-12的月

%c

1-12的月份數(shù)值

%d

01-31的某月里面的第幾天

%e

1-31的某月里面的第幾天

%D

用th后綴表示某月中的第幾天

%j

001-366的一年中的第幾天

%a

星期幾對應(yīng)的英文縮寫

%W

星期幾對應(yīng)的英文全稱

%H

00-23的小時

%h

01-12的小時

%i

00-59的分鐘

%S

秒(00-59)

%f

微秒

時分秒

%T

返回當(dāng)前的時分秒, 24-小時 (hh:mm:ss)

select date_format("2019-12-25 22:47:37","%Y-%m-%d")

通過運行上面的代碼,就會返回4位數(shù)的年、01-12的月、01-31的天,三者之間且用-分隔開來,即2019-12-25。

這里需要注意下1和01的區(qū)別,本質(zhì)上都是表示的1,但是展示上會有些不太一樣,比如下面代碼中,我們的原日期是2019-1-1,但是返回的結(jié)果是2019-01-01的。

select date_format("2019-1-1 22:47:37","%Y-%m-%d")
select date_format("2019-12-25 22:47:37","%H:%i:%S")

通過運行上面的代碼就會返回00-23的小時、00-59的分、00-59的秒,三者之間用:分隔開來,即22:47:37。

除了date_format()函數(shù)以外,還有另外一個函數(shù)extract,用于返回一個具體日期時間中的單獨部分,比如年、月、日、小時、分鐘等等。具體形式如下:

extract(unit from datetime)

datetime表示具體的日期時間,unit表示要從datetime中返回的單獨的部分。unit值可以是下列的值:

unit

說明

year

month

day

hour

小時

minute

分鐘

second

week

周數(shù),全年第幾周

select
 extract(year from "2019-12-25 22:47:37") as col1
 ,extract(month from "2019-12-25 22:47:37") as col2
 ,extract(day from "2019-12-25 22:47:37") as col3

通過運行上面的代碼,就會分別獲取到datetime中的年月日,具體結(jié)果如下:

col1

col2

col3

2019

12

25

3.日期時間運算

有的時候我們也需要對日期之間進(jìn)行運算,比如我要獲取今天往前7天對應(yīng)的日期,或者今天往后13天對應(yīng)的日期,可以去翻日歷,也可以去數(shù)數(shù),但是這些方法肯定都不是最直接的方法。所以需要日期之間的運算。

3.1向后偏移時間

比如我們要獲取今天之后的x天對應(yīng)的日期,就是相當(dāng)于在今天日期的基礎(chǔ)上加x天,我們把這叫做向后偏移,這個時候就可以使用date_add()函數(shù),具體形式如下:

date_add(date,interval num unit)

date表示當(dāng)前的日期,或者當(dāng)前的日期時間;interval是一個固定的參數(shù);num為上面講到的x;unit表示你要加的單位,是往后移動7天,還是7月,還是7年,可選值與extract函數(shù)中unit的可選值是一樣的。

select 
 "2019-01-01" as col1
 ,date_add("2019-01-01",interval 7 year) as col2
 ,date_add("2019-01-01",interval 7 month) as col3
 ,date_add("2019-01-01",interval 7 day) as col4

通過運行上面的代碼,就會返回2019-01-01往后7年、7月、7天對應(yīng)的日期,具體結(jié)果如下:

col1

col2

col3

col4

2019-01-01

2026-01-01

2019-08-01

2019-01-08

select 
 "2019-01-01 01:01:01" as col1
 ,date_add("2019-01-01 01:01:01",interval 7 hour) as col2
 ,date_add("2019-01-01 01:01:01",interval 7 minute) as col3
 ,date_add("2019-01-01 01:01:01",interval 7 second) as col4

通過運行上面的代碼,就會返回2019-01-01 01:01:01往后7小時、7分鐘、7秒對應(yīng)的日期,具體結(jié)果如下:

col1

col2

col3

col4

2019-01-01 01:01:01

2019-01-01 08:01:01

2019-01-01 01:08:01

2019-01-01 01:01:08

3.2向前偏移時間

有向后偏移,就會有向前偏移。比如我們要獲取今天之前的若干天,就是相當(dāng)于是在當(dāng)前日期的基礎(chǔ)上減去x天,這個時候我們使用的是date_sub()函數(shù),date_sub與date_add的函數(shù)形式是一樣的。把上面代碼中的date_add換成date_sub就表示向前偏移。

select 
 "2019-01-01" as col1
 ,date_sub("2019-01-01",interval 7 year) as col2
 ,date_sub("2019-01-01",interval 7 month) as col3
 ,date_sub("2019-01-01",interval 7 day) as col4

通過運行上面的代碼,就會返回2019-01-01往前7年、7月、7天對應(yīng)的日期,具體結(jié)果如下:

col1

col2

col3

col4

2019-01-01

2012-01-01

2018-06-01

2018-12-25

向前偏移指定的時間,我們除了使用date_sub以外,我們還可以繼續(xù)使用date_add,只不過把加的具體num值換成負(fù)數(shù)就行,比如7換成-7即可,具體實現(xiàn)代碼如下:

select 
 "2019-01-01" as col1
 ,date_add("2019-01-01",interval -7 year) as col2
 ,date_add("2019-01-01",interval -7 month) as col3
 ,date_add("2019-01-01",interval -7 day) as col4

通過運行上面的結(jié)果與使用date_sub得出來的結(jié)果是一致的。

3.3兩日期做差

上面講完了向前偏移、向后偏移,我們有的時候還需要獲取兩日期之差,使用的datediff()函數(shù),datediff用于返回兩日期之間相差的天數(shù),函數(shù)形式如下:

datediff(end_date,start_date)

我們是用end_date去減start_date的。

select datediff("2019-01-07","2019-01-01")

通過運行上面的代碼,會返回2019-01-07與2019-01-01之間的天數(shù)差,結(jié)果為6。

你還可以看:

Sql 的執(zhí)行順序是怎樣的?

到此這篇關(guān)于Mysql日期時間函數(shù)的文章就介紹到這了,更多相關(guān)Mysql日期時間函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL DATE_ADD和ADDDATE函數(shù)實現(xiàn)向日期添加指定時間間隔
  • MySQL DATEDIFF函數(shù)獲取兩個日期的時間間隔的方法
  • MySQL日期函數(shù)與時間函數(shù)匯總(MySQL 5.X)
  • MySQL獲得當(dāng)前日期時間函數(shù)示例詳解
  • MySQL日期與時間函數(shù)的使用匯總
  • mysql 實現(xiàn)添加時間自動添加更新時間自動更新操作

標(biāo)簽:徐州 黔東 拉薩 沈陽 鹽城 沈陽 珠海 移動

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《一篇文章搞定Mysql日期時間函數(shù)》,本文關(guān)鍵詞  一篇,文章,搞定,Mysql,日期,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《一篇文章搞定Mysql日期時間函數(shù)》相關(guān)的同類信息!
  • 本頁收集關(guān)于一篇文章搞定Mysql日期時間函數(shù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 黄色网页免费观看| 一级大毛片| 围产精品久久久久久久精品三级| 粗大的内捧猛烈进出在线视频 | 91亚洲自偷手机在线观看| 高H文纯肉全肉咬奶头校园| 五月色婷婷久久综合亚瑟| 动漫深夜动态福利gif动态图ufo| 天海冀一二三区| 精品无码一区二区三区蜜桃| 美女张开腿扒开内裤让男人桶| 美女扒开屁股让男生视频| 男人j桶进女人p无遮挡在线观看| 伊人久久天堂| 狂C亲女含苞欲h小黄文| 人妻熟妇国产乱码精品精| 国模一区二区三区四区精品| 亚洲淫视频| 8090电影院| 男人边摸屁股边舌吻高清视频| 女明星的一级毛片视频| 日本jizz强视频69视频| 国产精品偷窥盗摄视频无码| 女厕厕露p撒尿| 美女全身裸妆图片| 微微一笑很倾城干贝微微乳液| 女人张开腿被舔下面| 黄色特级毛片| 快灬快灬?一下爽喷水| 少妇人妻天堂性色AV在线软件| 女同肉| 最近免费韩国高清在线观看视频| 91精品国产综合久久香蕉麻豆 | 免费中文字幕在线国语| 国产v片在线观看免费播放| 午夜爱爱动态图| 男人舔女人的阴道视频| 手指喷水h| 刘晓庆情史恶性事件| free性a欧美| 青青青国产在线观看|