日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql的max_allowed_packet配置

發布時間:2023/12/16 数据库 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql的max_allowed_packet配置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

開發中經常出現批量的插入或者更新操作,當批量操作的數據較多時,比如到了幾萬行數據,會遇到操作數據庫報錯的情況,這個其中一種原因就是max_allowed_packet的配置問題,max_allowed_packet配置了數據庫單次執行sql語句的大小,若超出配置的大小,就會出現報錯。

錯誤信息:

1、Packets larger than max_allowed_packet are not allowed

2、Packet?for?query?is?too?large?(1706?>?1024).?You?can?change?this?value?on?the?server?by?setting?the?max_allowed_packet'?variable.

3、程序(如python里面executemany)在插入大量數據時出現"MySQL server has gone away"

如何查看max_allowed_packet配置:

查詢語句:

SHOW GLOBAL VARIABLES;

或?show variables like '%max_allowed_packet%'

查詢結果:

max_allowed_packet ? ?4194304


備注:本機是windows下的5.7.23版本的mysql,默認是4194304byte,即4M。

方式一:sql語句修改

  1、首先登陸mysql查看當前該值的大小。

    show variables like '%max_allowed_packate%'

???? 2、修改其大小為1G(1024*1024=1M)

???????????set global max_allowed_packet = 1024*1024*1024

  這種修改方式修改后,需要重新登陸Mysql查看,才能看到修改后的值。并且,這種方式修改的mysql max_allowed_packet,在Mysql重啟后,可能失效。

方式二:my.ini修改

  1、在my.ini文件中添加如下語句。比如:改為1G.如下圖所示。修改完成后,需要重啟mysql。

  


注意:方式2中max_allowed_packed一定是添加在【mysqld】才能生效。

方式三:linux系統中my.ini修改

linux系統中,my.ini文件在/etc/my.cnf文件中,可直接打開此文件,修改下面兩行,主要是第二行。如果文件中沒有這兩行,可直接插入。

保存并退出后,需要重啟mysql服務

重啟命令:service mysql restart.

再次運行show variables like '%max_allowed_packate%'?可發現該值已有變化

?附,linux操作指令:

進入文件夾?cd /etc

找到文件 ls

打開文件 vi my.cnf

編輯? a

保存?按“esc”后,

linux系統下保存命令分八種情況:保存但不退出:“:w” ;將修改保存到file中不退出vi:“:w file” ;強制保存,不退出vi:“:w! ”;保存并退出vi:“:wq”;強制保存并退出vi:“:wq!”;不保存退出vi:“q:”;不保存強制退出vi:“:q!”;放棄修改:“:e!”。

總結

以上是生活随笔為你收集整理的mysql的max_allowed_packet配置的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。