bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

PHP查詢MySQL大量數據的內存占用分析

2023-01-10    分類: 網站建設

PHP查詢MySQL大量數據的內存占用分析

這篇文章主要是從原理, 手冊和源碼分析在PHP中查詢MySQL返回大量結果時, 內存占用的問題, 同時對使用MySQL C API也有涉及.

昨天, 有同事在PHP討論群里提到, 他做的一個項目由于MySQL查詢返回的結果太多(達10萬條), 從而導致PHP內存不夠用. 所以, 他問, 在執行下面的代碼遍歷返回的MySQL結果之前, 數據是否已經在內存中了? - while($row=mysql_fetch_assoc($result)){ //...

}

當然, 這種問題有許多優化的方法. 不過, 就這個問題來講, 我首先想到, MySQL是經典的C/S(Client/Server, 客戶端/服務器)模型, 在遍歷結果集之前, 底層的實現可能已經把所有的數據通過網絡(假設使用TCP/IP)讀到了Client的緩沖區, 也有另一種可能, 就是數據還在Server端的發送緩沖區里, 并沒有傳給Client.

在查看PHP和MySQL的源碼之前, 我注意到PHP手冊里有兩個功能相近的函數: mysql_query()

mysql_unbuffered_query()

兩個函數的字面意思和說明證實了我的想法, 前一個函數執行時, 會把所有的結果集從Server端讀到Client端的緩沖區中, 而后一個則沒有, 這就是”unbuffered(未緩沖)”的意思.

那就是說, 如果用mysql_unbuffered_query()執行了一條返回大量結果集的SQL語句, 在遍歷結果之前, PHP的內存是沒有被結果集占用的. 而用mysql_query()來執行同樣的語句的話, 函數返回時, PHP的內存占用便會急劇增加, 立即耗光內存.

如果閱讀PHP的相關代碼, 可以看到這兩個函數的實現上的異同: /*{{{protoresourcemysql_query(stringquery[,intlink_identifier]) SendsanSQLquerytoMySQL*/ PHP_FUNCTION(mysql_query) { php_mysql_do_query(INTERNAL_FUNCTION_PARAM_PASSTHRU,MYSQL_STORE_RESULT); } /*}}}*/ /*{{{protoresourcemysql_unbuffered_query(stringquery[,intlink_identifier]) SendsanSQLquerytoMySQL,withoutfetchingandbufferingtheresultrows*/ 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端, 前者只是讀取了結果集的元信息.
回到PHP, 使用mysql_unbuffered_query(), 可以避免內存的立即占用. 如果在遍歷的過程不對結果進行”PHP緩存”(如放到某數組中), 則整個執行過程雖然操作了十萬條或者百萬條或者更多的數據, 但PHP占用的內存始終是非常小的.

標簽:成都網站制作 高端網

分享題目:PHP查詢MySQL大量數據的內存占用分析
標題路徑:http://vcdvsql.cn/news/229570.html

成都網站建設公司_創新互聯,為您提供搜索引擎優化網站改版網站維護品牌網站設計品牌網站建設網頁設計公司

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

微信小程序開發