1。在mysql的命令模式下使用
創新互聯是由多位在大型網絡公司、廣告設計公司的優秀設計人員和策劃人員組成的一個具有豐富經驗的團隊,其中包括網站策劃、網頁美工、網站程序員、網頁設計師、平面廣告設計師、網絡營銷人員及形象策劃。承接:成都網站制作、網站設計、外貿網站建設、網站改版、網頁設計制作、網站建設與維護、網絡推廣、數據庫開發,以高性價比制作企業網站、行業門戶平臺等全方位的服務。
mysql
select
CURTIME();
或
mysql
select
now();
看當前時間是否正確,可以看到mysql當前使用的是那一個時區的時間。
2。在mysql命令行中更改時區
mysql
SET
time_zone
=
'+8:00';
#
此為北京時,我們所在東8區
mysql
flush
privileges;
#
立即生效
此時mysql時區已更改正確,與系統時區都使用為
Shanghai時間了。
####
這種方法好像只能在終端上使用,退出終端后時間又會變成原來的,看來只能重啟mysql了。
3。重啟mysql也應沒有問題,此時mysql會主動讀取系統時間。
方法二:
如果mysql數據庫可以重啟,直接重啟,mysql應可以立即主動讀取系統時間,如果不行則更改mysql的配置文件(mysql.cnf)
在my.cnf的
[mysqld]區域中加上
default-time_zone
=
'+8:00'
#此為北京時。
補充:
如果想臨時解決時間顯示問題,可以用php或其他語言動態修改下mysql的時區。
具體方法:
在mysql_connect()下使用mysql_query("SET
time_zone
=
'+8:00'")。
這樣可以在保證你不重啟的情況下改變時區。但是mysql的某些系統函數還是不能用如:now()。
MYSQL_OPT_READ_TIMEOUT 是 MySQL c api 客戶端中用來設置讀取超時時間的參數。在 MySQL 的官方文檔中,該參數的描述是這樣的:
MYSQL_OPT_READ_TIMEOUT (argument type: unsigned int *)The timeout in seconds for each attempt to read from the server. There are retries if necessary, so the total effective timeout value is three times the option value. You can set the value so that a lost connection can be detected earlier than the TCP/IPClose_Wait_Timeout value of 10 minutes.
也就是說在需要的時候,實際的超時時間會是設定值的 3 倍。但是實際測試后發現實際的超時時間和設置的超時時間一致。
而具體什么時候發生三倍超時,在文檔中沒有找到。所以對 MySQL 5.7.20 的源碼進行了一些分析。
使用 GDB 調試代碼找了實際與 mysql server 通信的代碼,如下:
請點擊輸入圖片描述
其中 vio_read() 函數中,使用 recv 和 poll 來讀取報文和做讀取超時。net_should_retry() 函數只有在發生 EINTR 時才會返回 true。從這段代碼來看是符合測試結果的,并沒有對讀取進行三次重試。只有在讀取操作被系統中斷打斷時才會重試,但是這個重試并沒有次數限制。
從上面代碼的分析可以看出,代碼的邏輯和文檔的描述不符。于是在一頓搜索后,找到了一個 MySQL 的 BUG(Bug #31163)。該 BUG 報告了在?MySQL?5.0 中,MySQL c api 讀取的實際超時時間是設置的三倍,與現有文檔描述相符。于是對 MySQL 5.0.96 的代碼又進行分析。
同樣使用 GDB 找到了通信部分的代碼。這次找到了重試三次的代碼,如下:
請點擊輸入圖片描述
這個版本的 MySQL api 的讀寫超時是直接使用的 setsockopt 設置的。第一次循環,在 A 點發生了第一次超時(雖然注釋寫的非阻塞,但是客戶端的連接始終是阻塞模式的)。然后在 B 點將該 socket 設置為阻塞模式,C 點這里重置 retry 次數。由于設置了 alarm 第二次以后的循環會直接進入 D 點的這個分支,并且判斷循環次數。作為客戶端時net-retry_count 始終是 1,所以重試了兩次,共計進行了 3 次 vioread 后從 E 點退出函數。
由上面的分析可知,MySQL 文檔對于該參數的描述已經過時,現在的 MYSQL_OPT_READ_TIMEOUT 并不會出現三倍超時的問題。而 Bug #31163 中的處理結果也是將文檔中該參數的描述更新為實際讀取超時時間是設定時間的三倍。也許是 MySQL 的維護者們在后續版本更新時忘記更新文檔吧。
東京的時區是東九區,比我們北京東八區多1個時區,所以+9就是東京時間了
那我們怎么修改,有兩種方法,一種是臨時的,一種是長久的。
一:通過sql命令臨時修改
# 設置全局時區 mysql set global time_zone = '+8:00';
Query OK, 0 rows affected (0.00 sec)
# 設置時區為東八區 mysql set time_zone = '+8:00';
Query OK, 0 rows affected (0.00 sec)
# 刷新權限使設置立即生效 mysql flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql show variables like '%time_zone%';
+------------------+--------+
| Variable_name | Value |
+------------------+--------+
| system_time_zone | EST |
| time_zone | +08:00 |
+------------------+--------+
2 rows in set (0.00 sec)
二:修改my.cnf實現永久修改
vi /etc/mysql/my.cnf
然后在mysqld下邊的配置中添加一行:
default-time_zone = '+8:00'
然后重啟mysql
service mysql restart
怎樣修改mysql中的時間和日期?
建議你安裝PHPMYADMIN或者MYSQL-FRONT這類軟件,用它們來修改就比較簡單。
另外一個辦法,在留言前修改服務器的系統時間,這樣保存的留言就是以前的。
具體操作步驟如下:
1、第一步,打開sql數據庫,新建一個表。格式原因,以下的date_time和time_time為日期類型,如圖所示。
2、第二步,若是簡單的查詢表,那么就會以日期格式顯示出來,如圖所示。
3、第三步,使用函數to_char,把查詢日期顯示結果更改成日期形式,獲得以下結果,如圖所示。
4、第四步,點擊查詢編輯器選項,鍵入以下代碼,如圖所示。
5、第五步,可以看到日期就修改好了,如圖所示。
docker中的mysql時區是使用了世界標準時間(UTC),把時區改成東八區方法:
1、啟動容器時設置: 添加如下配置:
2、進入docker配置:(重啟才能生效--永久生效)
3、臨時修改(從mysql上修改,重啟失效)
名稱欄目:怎么修改mysql時間,mysql 修改時間
網站網址:http://vcdvsql.cn/article36/hsdspg.html
成都網站建設公司_創新互聯,為您提供App設計、網站設計、軟件開發、動態網站、網站建設、外貿建站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯