1、應用程序(比如PHP)長時間的執行批量的MYSQL語句。
最常見的就是采集或者新舊數據轉化。
解決方案:
在my.ini文件中添加或者修改以下兩個變量:
wait_timeout=2880000
interactive_timeout = 2880000
關於兩個變量的具體說明可以google或者看官方手冊。
如果不能修改my.cnf,則可以在連接數據庫的時候設置CLIENT_INTERACTIVE,比如:
sql = "set interactive_timeout=24*3600";
mysql_real_query(...)
2、執行一個SQL,但SQL語句過大或者語句中含有BLOB或者longblob字段。
比如,圖片數據的處理
解決方案
在my.cnf文件中添加或者修改以下變量:
max_allowed_packet = 10M (也可以設置自己需要的大小)
max_allowed_packet 參數的作用是,用來控制其通信緩沖區的最大長度。
mysql根據配置文件會限制server接受的數據包大小。
有時候大的插入和更新會被max_allowed_packet 參數限制掉,導致失敗。
查看目前配置
show VARIABLES like '%max_allowed_packet%';
顯示的結果為:
+--------------------+---------+ | Variable_name | Value | +--------------------+---------+ | max_allowed_packet | 1048576 | +--------------------+---------+
以上說明目前的配置是:1M
修改方法
1) 方法1
可以編輯my.cnf來修改(windows下my.ini),在[mysqld]段或者mysql的server配置段進行修改。
max_allowed_packet = 20M
如果找不到my.cnf可以通過
mysql --help | grep my.cnf
去尋找my.cnf文件。
2) 方法2
(很妥協,很糾結的辦法)
進入mysql server
在mysql 命令行中運行
set global max_allowed_packet = 2*1024*1024*10
然后關閉掉這此mysql server鏈接,再進入。
show VARIABLES like '%max_allowed_packet%';
查看下max_allowed_packet是否編輯成功