PHP的mysqli_query參數MYSQLI_STORE_RESULT和MYSQLI_USE_RESULT的區別

來源:互聯網
上載者:User

標籤:

這篇文章主要介紹了PHP的mysqli_query參數MYSQLI_STORE_RESULT和MYSQLI_USE_RESULT的區別,本文給出了這兩個參數的5個區別,需要的朋友可以參考下

 

雖然nosql變得流行,但是我感覺sql還是主流
今天在翻php manul的時候,發現mysqli 的查詢可以傳遞一個有意思的參數

@mysqli_query($this->sql,$SQL,($method ? MYSQLI_USE_RESULT : MYSQLI_STORE_RESULT));

在php manul上面對這兩個參數是這樣解釋的。

Either the constant MYSQLI_USE_RESULT or MYSQLI_STORE_RESULT depending on the desired behavior. By default, MYSQLI_STORE_RESULT is used.

如果什麼也不傳,那就預設為MYSQLI_STORE_RESULT。

在phpmanul上面有人說了這樣一句話If we have to retrieve large amount of data we use MYSQLI_USE_RESULT

其實這兩個參數的區別還是很大的。

(1)區別在於從伺服器上檢索結果集的行。
(2)MYSQLI_USE_RESULT 啟動查詢,但實際上並未擷取任何行
(3)MYSQLI_STORE_RESULT 立即檢索所有的行
(4)MYSQLI_STORE_RESULT 從伺服器上檢索結果集時,就提取了行,並為之分配記憶體,儲存到客戶機中,隨後調用 mysqli_fetch_array()就再也不會返回錯誤,因為它僅僅是把行脫離了已經保留結果集的資料結構,mysqli_fetch_array()返回 NULL始終表示已經到達結果集的末端。
(5)MYSQLI_USE_RESULT 本身不檢索任何行,而只是啟動一個逐行的檢索,就是說必須對每行調用 mysqli_fetch_array()來自己完成。既然如此,雖然正常情況下,mysqli_fetch_array()返回NULL仍然表示此時已到達結果集的末端,但也可能表示在與伺服器通訊時發生錯誤。

總結

與MYSQLI_USE_RESULT相比,MYSQLI_STORE_RESULT 有著較高的記憶體和處理需求,因為是在客戶機上維護整個結果集,所以記憶體配置和建立資料結構的耗費是非常巨大的,如果想一次檢索多個行,可用 MYSQLI_USE_RESULT。

MYSQLI_USE_RESULT有著較低的記憶體需求,因為只需給每次處理的單行分配足夠的空間。這樣速度就較快,因為不必為結果集建立複雜的資料結構。另一方面,MYSQLI_USE_RESULT把較大的負載加到了伺服器上,它必須保留結果集中的行,直到客戶機看起來適合檢索所有的行。

 

參考閱讀:http://www.manongjc.com/article/1195.html

PHP的mysqli_query參數MYSQLI_STORE_RESULT和MYSQLI_USE_RESULT的區別

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.