怎么查看mysql時區(qū) 查看mysql的時區(qū)

mysql修改和查看時區(qū)(十五)

1. 查看時區(qū)命令

南平ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

2.?GMT、UTC、DST、CST時區(qū)代表的意義

2.1 GMT:Greenwich Mean Time?

2.2?UTC: Coordinated Universal Time

2.3?DST: Daylight Saving Time

2.4?CST:Central Standard Time

3.? 修改時區(qū)

3.1?僅修改當(dāng)前會話的時區(qū),停止會話失效(CET)

3.2 修改全局的時區(qū)配置

技術(shù)分享 | MySQL:一文弄懂時區(qū)&time_zone

你還在被以下問題困擾嗎:

MySQL 的安裝規(guī)范中應(yīng)該設(shè)置什么時區(qū)?

JAVA 應(yīng)用讀取到的時間和北京時間差了14個小時,為什么?怎么解決?

已經(jīng)運行一段時間的業(yè)務(wù),修改 MySQL 的時區(qū)會影響已經(jīng)存儲的時間類型數(shù)據(jù)嗎?

遷移數(shù)據(jù)時會有導(dǎo)致時間類型數(shù)據(jù)時區(qū)錯誤的可能嗎?

...

看完這篇文章,你能解決上面所有的疑惑。首先出場的是和時區(qū)相關(guān)的啟動參數(shù)和系統(tǒng)變量。

如果要在 MySQL 啟動時就指定時區(qū),則應(yīng)該使用啟動參數(shù): default-time-zone ,示例:

啟動后我們可以看到控制時區(qū)的系統(tǒng)變量,其中 time_zone 變量控制時區(qū),在MySQL運行時可以通過 set 命令修改(注意:不可以寫在 my.cnf 中):

啟動參數(shù)和系統(tǒng)變量的可用值遵循相同的格式:

system_time_zone 變量只有全局值沒有會話值,不能動態(tài)修改,MySQL 啟動時,將嘗試自動確定服務(wù)器的時區(qū),并使用它來設(shè)置 system_time_zone 系統(tǒng)變量, 此后該值不變。當(dāng) time_zone='system' 時,就是使用的這個時區(qū),示例中 time_zone 就是 CST,而 CST 在 RedHat 上就是東八區(qū):

概括一下就兩點:

1. NOW() 和 CURTIME() 系統(tǒng)函數(shù)的返回值受當(dāng)前 session 的時區(qū)影響

不僅是select now(),包括insert .. values(now())、以及字段的 DEFAULT CURRENT_TIMESTAMP 屬性也受此影響:

2. timestamp 數(shù)據(jù)類型字段存儲的數(shù)據(jù)受時區(qū)影響

timestamp 數(shù)據(jù)類型會存儲當(dāng)時session的時區(qū)信息,讀取時會根據(jù)當(dāng)前 session 的時區(qū)進行轉(zhuǎn)換;而 datetime 數(shù)據(jù)類型插入的是什么值,再讀取就是什么值,不受時區(qū)影響。也可以理解為已經(jīng)存儲的數(shù)據(jù)是不會變的,只是 timestamp 類型數(shù)據(jù)在讀取時會根據(jù)時區(qū)轉(zhuǎn)換:

關(guān)于時區(qū)所有明面上的東西都在上面了,我們前面提到的困擾就是在暗處的經(jīng)驗。

1. MySQL的安裝規(guī)范中應(yīng)該設(shè)置什么時區(qū)?

對于國內(nèi)的業(yè)務(wù)了,在 my.cnf 寫入 default-time-zone='+08:00' `,其他地區(qū)和開發(fā)確認(rèn)取對應(yīng)時區(qū)即可。

為什么不設(shè)置為 system 呢?使用系統(tǒng)時間看起來也是個不錯的選擇,比較省事。不建議的原因有兩點:

2. JAVA應(yīng)用讀取到的時間和北京時間差了14個小時,為什么?怎么解決?

這通常是 JDBC 參數(shù)中沒有為連接設(shè)置時區(qū)屬性(用 serverTimezone 參數(shù)指定),并且MySQL中沒有設(shè)置全局時區(qū),這樣MySQL默認(rèn)使用的是系統(tǒng)時區(qū),即 CST。這樣一來應(yīng)用與MySQL 建立的連接的 session time_zone 為 CST ,前面我們提到 CST 在 RedHat 上是 +08:00 時區(qū),但其實它一共能代表4個時區(qū):

JDBC在解析CST時使用了美國標(biāo)準(zhǔn)時間,這就會導(dǎo)致時區(qū)錯誤。要解決也簡單:一是遵守上面剛說到的規(guī)范,對MySQL顯示的設(shè)置'+08:00'時區(qū);二是JDBC設(shè)置正確的 serverTimezone。

3. 已經(jīng)運行一段時間的業(yè)務(wù),修改MySQL的時區(qū)會影響已經(jīng)存儲的時間類型數(shù)據(jù)嗎?

完全不會,只會影響對 timestamp 數(shù)據(jù)類型的讀取。這里不得不提一句,為啥要用 timestamp?用 datetime 不香嗎,范圍更大,存儲空間其實差別很小,趕緊加到開發(fā)規(guī)范中吧。

4. 遷移數(shù)據(jù)時會有導(dǎo)致時間類型數(shù)據(jù)時區(qū)錯誤的可能嗎?

這個還真有,還是針對 timestamp 數(shù)據(jù)類型,比如使用 mysqldump 導(dǎo)出 csv 格式的數(shù)據(jù),默認(rèn)這種導(dǎo)出方式會使用 UTC 時區(qū)讀取 timestamp 類型數(shù)據(jù),這意味導(dǎo)入時必須手工設(shè)置 session.time_zone='+00:00'才能保證時間準(zhǔn)確:

如何避免?mysqldump 也提供了一個參數(shù) --skip-tz-utc ,意思就是導(dǎo)出數(shù)據(jù)的那個連接不設(shè)置 UTC 時區(qū),使用 MySQL 的 gloobal time_zone 系統(tǒng)變量值。

其實 mysqldump 導(dǎo)出 sql 文件時默認(rèn)也是使用 UTC 時區(qū),并且會在導(dǎo)出的 sql 文件頭部帶有 session time_zone 信息,這樣可以保證導(dǎo) SQL 文件導(dǎo)入和導(dǎo)出時使用相同的時區(qū),從而保證數(shù)據(jù)的時區(qū)正確(而導(dǎo)出的 csv 文件顯然不可以攜帶此信息)。需要注意的是 --compact 參數(shù)會去掉 sql 文件的所有頭信息,所以一定要記得: --compact 參數(shù)得和 --skip-tz-utc 一起使用。

mysql獲取當(dāng)前系統(tǒng)日期和時間

可以了解一下MySQL的時間戳(Timestamp)數(shù)據(jù)類型:

默認(rèn)時間戳(Timestamp)類型的取值范圍為'1970-01-01 00:00:01' UTC至'2038-01-19 03:14:07' UTC,數(shù)據(jù)精確到秒級別,該取值范圍包含約22億個數(shù)值,因此在MySQL內(nèi)部使用4個字節(jié)INT類型來存放時間戳數(shù)據(jù):

1、在存儲時間戳數(shù)據(jù)時,先將本地時區(qū)時間轉(zhuǎn)換為UTC時區(qū)時間,再將UTC時區(qū)時間轉(zhuǎn)換為INT格式的毫秒值(使用UNIX_TIMESTAMP函數(shù)),然后存放到數(shù)據(jù)庫中。

2、在讀取時間戳數(shù)據(jù)時,先將INT格式的毫秒值轉(zhuǎn)換為UTC時區(qū)時間(使用FROM_UNIXTIME函數(shù)),然后再轉(zhuǎn)換為本地時區(qū)時間,最后返回給客戶端。

(Timestamp)時間戳列可以有四張組合定義,其含義分別為:

1、當(dāng)字段定義為timestamp,表示該字段在插入和更新時都不會自動設(shè)置為當(dāng)前時間。

2、當(dāng)字段定義為timestamp DEFAULT CURRENT_TIMESTAMP,表示該字段僅在插入且未指定值時被賦予當(dāng)前時間,再更新時且未指定值時不做修改。

3、當(dāng)字段定義為timestamp ON UPDATE CURRENT_TIMESTAMP,表示該字段在插入且未指定值時被賦值為"0000-00-00 00:00:00",在更新且未指定值時更新為當(dāng)前時間。

4、當(dāng)字段定義為timestamp DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,表示該字段在插入或更新時未指定值,則被賦值為當(dāng)前時間。

分享名稱:怎么查看mysql時區(qū) 查看mysql的時區(qū)
網(wǎng)站網(wǎng)址:http://muchs.cn/article38/dossesp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、網(wǎng)站內(nèi)鏈、營銷型網(wǎng)站建設(shè)、用戶體驗外貿(mào)建站、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)