Thinkphp中的Model操作有兩個方法:add()和addAll
addAll方法可以做到批量添加數據的功能,也就是MySQL的這種用法:
數據量很多情況下盡量選擇批量插入而不是循環逐條插入,否則你的數據庫會吃不住掛掉。
不過如果你想當然的將所有數據全部存入一個數組并進行addAll也同樣會面臨掛掉的情況,這是為什么呢?
原因就是mysql中max_allowed_packet變量的配置限制了上傳sql語句的長度,在mysql配置中將他配置大一點就行了
max_allowed_packet = 100M
同時在插入數據時也做好批量插入的長度限制,畢竟你不知道什么時候數據會變成百萬級別的。
以上就是本文的全部內容了,希望小伙伴們能夠喜歡。
新聞熱點
疑難解答