萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> Navicat中MySQL server has gone away錯誤怎麼辦

Navicat中MySQL server has gone away錯誤怎麼辦

mysql數據庫出現MySQL server has gone away錯誤一般是sql語句太大導致了,下面們在使用Navicat中操作數據庫時提示MySQL server has gone away問題解決辦法。

今天備份了一下本站的數據,生成的sql文件比較大,當然,這個sql是包含了比較多的冗余數據。用Navicat直接導入的話,報錯MySQL server has gone away。如下圖所示:

mysql-server-has-gone-away-on-navicat

解決辦法

打開navicat的菜單中的tools,選擇server monitor,然後在左列選擇數據庫,右列則點選variable表單項,尋找max_allowed_packet,將其值改大。

mysql-server-has-gone-away-on-navicat

改好之後,再次導入備份的sql文件,一切正常。

如果還是無法解決,下面我整理了一些mysql查詢中碰到MySQL server has gone away問題

找到你的mysql目錄下的my.ini配置文件,加入以下代碼:

max_allowed_packet=500M

wait_timeout=288000

interactive_timeout = 288000

自己看情況更改數值,我直接改很大,最後記得重啟你的mysql服務

這樣的話就能很好的解決MySQL server has gone away問題了。max_allowed_packet是mysql允許最大的數據包,也就是你發送的請求; wait_timeout是等待的最長時間,這個值大家可以自定義,但如果時間太短的話,超時後就會現了MySQL server has gone away #2006錯誤。max_allowed_packet參數的作用是,用來控制其通信緩沖區的最大長度

如果沒有修改myql權限我們可以在PHP程序裡面,如果php.ini修改起來不方便,可以以下代碼來嘗試解決。

ini_set('mysql.connect_timeout', 300);
 
ini_set('default_socket_timeout', 300);
 
在ini_set後,可以用ini_get來驗證參數設置適合符合預期。

copyright © 萬盛學電腦網 all rights reserved