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

歡迎訪問 生活随笔!

生活随笔

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

数据库

php查询mysql返回大量数据结果集导致内存溢出的解决方法

發布時間:2023/12/10 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php查询mysql返回大量数据结果集导致内存溢出的解决方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

web開發中如果遇到php查詢mysql返回大量數據導致內存溢出、或者內存不夠用的情況那就需要看下MySQL C API的關聯,那么究竟是什么導致php查詢mysql返回大量數據時內存不夠用情況?

答案是: mysql_query 和 mysql_unbuffered_query 兩個函數

????????首先來分析一個典型的實例:在執行下面的代碼的時候就會導致php請求mysql返回結果太多(10W以上)導致PHP內存不夠用。

while ($row = mysql_fetch_assoc($result))?

{

??? // …

}

????????對于上面的問題來講,首先要從mysql的原理上來分析?MySQL是經典的C/S(Client/Server, 客戶端/服務器)模型, 在遍歷結果集之前, 底層的實現可能已經把所有的數據通過網絡(假設使用TCP/IP)讀到了Client的緩沖區, 也有另一種可能, 就是數據還在Server端的發送緩沖區里, 并沒有傳給Client。

????????通過查看php和mysql的源碼中發現兩個相似的mysql函數:mysql_query() 和mysql_unbuffered_query(),

發現前一個函數執行時, 會把所有的結果集從Server端讀到Client端的緩沖區中, 而后一個則沒有, 這就是“unbuffered(未緩沖)”的意思。也就是說, 如果用mysql_unbuffered_query()?執行了一條返回大量結果集的SQL語句, 在遍歷結果之前, PHP的內存是沒有被結果集占用的。 而用mysql_query()?來執行同樣的語句的話, 函數返回時, PHP的內存占用便會急劇增加, 立即耗光內存。
PHP_FUNCTION(mysql_query)
{
???? php_mysql_do_query(INTERNAL_FUNCTION_PARAM_PASSTHRU, MYSQL_STORE_RESULT);
}
PHP_FUNCTION(mysql_unbuffered_query)
{
???? php_mysql_do_query(INTERNAL_FUNCTION_PARAM_PASSTHRU, MYSQL_USE_RESULT);
}

????????兩個函數都調用了php_mysql_do_query(), 只差了第2個參數的不同, MYSQL_STORE_RESULT和MYSQL_USE_RESULT. 再看php_mysql_do_query()的實現:

if(use_store?==?MYSQL_USE_RESULT)?
{
???? mysql_result=mysql_use_result(&mysql->conn);
}
??
else
{
???? mysql_result=mysql_store_result(&mysql->conn);
}

????????mysql_use_result()和mysql_store_result()是MySQL的C API函數, 這兩個C API函數的區別就是后者把結果集從MySQL Server端全部讀取到了Client端, 前者只是讀取了結果集的元信息。

????????扯遠了: 回到剛才的話題使用mysql_unbuffered_query(), 可以避免內存的立即占用, 如果返回的結果存放到array中也是完全沒有問題的, 也不會出現php查詢mysql數據量過大時導致內存溢出問題.

轉載于:https://www.cnblogs.com/mako/p/4156978.html

總結

以上是生活随笔為你收集整理的php查询mysql返回大量数据结果集导致内存溢出的解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 国产99久久九九精品无码免费 | 一区二区三区不卡在线 | av青青草原 | 日韩精品在线视频免费观看 | 夜色伊人 | 99国产精品99久久久久久 | 毛片大全 | 色综合久久久久无码专区 | 最新视频–x99av | 草莓视频18免费观看 | 久精品国产 | 高清乱码免费看污 | 免费av片| 日本一区二区三区四区在线观看 | 亚洲永久免费 | a毛片基地 | 国语播放老妇呻吟对白 | 女同动漫免费观看高清完整版在线观看 | 啪啪av网| 日本护士做爰视频 | 亚洲综合在线网 | 狠狠影院 | 懂色av一区二区三区免费观看 | 亚洲国产综合视频 | 国产精品5 | 四季av中文字幕一区 | 2018国产精品 | 女人张开腿让男人桶爽 | 丰腴饱满的极品熟妇 | 久久福利在线 | 久久亚洲成人 | 亚洲伦理天堂 | 久热久操 | 91精品国产综合久久久蜜臀 | 午夜激情av| 天堂中文8| 天天操网站| 多啪啪免费视频 | 九九爱精品 | 亚洲自拍偷拍av | 中文字幕制服诱惑 | 香蕉视频黄色在线观看 | 色婷婷久久久亚洲一区二区三区 | 日本孕妇孕交 | 国产片一区二区 | 国产午夜性春猛交ⅹxxx | 国产ts网站 | 成人激情视频网站 | 精品无码久久久久国产 | 国产亚洲AV无码成人网站在线 | 一区二区免费在线视频 | 成人在线观看一区二区三区 | 久久久久久久久久99 | 国产福利一区二区三区视频 | 国产伦理吴梦梦伦理 | 日韩成人免费在线视频 | а√中文在线资源库 | 国家队动漫免费观看在线观看晨光 | 色偷偷网 | 中文字幕av亚洲精品一部二部 | 久久蜜臀精品av | 在线观看二区 | 日本中文视频 | 婷婷成人在线 | 91av成人| 四虎影视成人永久免费观看亚洲欧美 | 美女日批在线观看 | 欧美福利在线观看 | 毛片网站在线播放 | 午夜秋霞 | 97超碰国产精品无码蜜芽 | se综合| 日韩黄片一区二区三区 | 精品国产免费观看 | 久久精品美女 | 亚洲精品黄色 | 淫片网站 | 韩国伦理av| 亚洲精品成人网 | 国产超碰人人爽人人做人人爱 | 成人综合影院 | 国产一级爽片 | 成年人的视频网站 | jizz免费观看 | 日韩中文字幕视频在线 | 欧美综合亚洲图片综合区 | 国产一区影院 | 国产精品久久77777 | 精品人妻互换一区二区三区 | 亚洲人人人| 亚洲巨乳在线 | 国产不卡精品 | 反差在线观看免费版全集完整版 | 粉嫩小箩莉奶水四溅在线观看 | 性猛交xxxx乱大交3 | 男人猛吃奶女人爽视频 | 91久久极品少妇xxxxⅹ软件 | 国产哺乳奶水91在线播放 | 超碰麻豆|