主頁(yè) > 知識(shí)庫(kù) > php優(yōu)化查詢(xún)foreach代碼實(shí)例講解

php優(yōu)化查詢(xún)foreach代碼實(shí)例講解

熱門(mén)標(biāo)簽:地圖標(biāo)注平臺(tái)怎么給錢(qián)注冊(cè) 釘釘打卡地圖標(biāo)注 常州地圖標(biāo)注服務(wù)商 衡水外呼系統(tǒng)平臺(tái) 福州人工外呼系統(tǒng)哪家強(qiáng) 安裝電銷(xiāo)外呼系統(tǒng) 百度商鋪地圖標(biāo)注 注冊(cè)400電話(huà)申請(qǐng) 新河科技智能外呼系統(tǒng)怎么樣

php代碼優(yōu)化

應(yīng)避免在php foreach里面進(jìn)行sql查詢(xún)
以下代碼示例使用了laravel的操作數(shù)據(jù)庫(kù)api,eloquent orm

foreach里面執(zhí)行兩次sql查詢(xún)

// $datas 要返回的數(shù)據(jù)
foreach ($datas as $_v) {
  // todo 在foreach中查詢(xún)了兩次 **time**: 290 ms(postman)
  $uid = $_v->uid;
  $_v->user_name  = User::find($uid)->username; // 1
  $_v->user_avatar = User::find($uid)->avatar;  // 2
}

foreach里面執(zhí)行一次sql查詢(xún)

foreach ($datas as $_v) {
  // todo
  // 簡(jiǎn)單的優(yōu)化使得兩次sql查詢(xún)變成一次
  // 在foreach中查詢(xún)了一次 **time**: 230 ms(postman)
  $user = User::find($_v->uid));   // 1
  $_v->user_name  = $user->username;
  $_v->user_avatar = $user->avatar;
}

將sql查詢(xún)移到foreach外面

上面兩個(gè)方法都不可避免的在foreach里面執(zhí)行了數(shù)據(jù)庫(kù)查詢(xún)
**應(yīng)避免在foreach中執(zhí)行sql查詢(xún)**
此處我的做法是再加一層foreach+if來(lái)代替sql查詢(xún)
// 本質(zhì)上是將foreach中的查詢(xún)移到外面
// $tmp_data_arr 是存儲(chǔ)在foreach外面執(zhí)行的數(shù)據(jù)庫(kù)查詢(xún)結(jié)果
foreach ($tmp_data_arr as $value) {
  foreach ($datas as $_v) {
    if ($_v->uid === $value['id']) { // **time**: 180 ms(postman)
      $_v->user_name  = $value['username'];
      $_v->user_avatar = $value['avatar'];
    }
  }
}

小結(jié)

// 返回?cái)?shù)據(jù)
return $datas;

經(jīng)過(guò)簡(jiǎn)單的優(yōu)化:時(shí)間(ms):290 -> 230 -> 180

到此這篇關(guān)于php優(yōu)化查詢(xún)foreach代碼實(shí)例講解的文章就介紹到這了,更多相關(guān)php優(yōu)化查詢(xún)foreach內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 淺談PHP性能優(yōu)化之php.ini配置
  • 詳解PHP優(yōu)化巨量關(guān)鍵詞的匹配
  • PHP引擎php.ini參數(shù)優(yōu)化深入講解
  • PHP安全配置優(yōu)化詳解
  • PHP內(nèi)存溢出優(yōu)化代碼詳解
  • PHP優(yōu)化教程之解決嵌套問(wèn)題
  • PHP解決高并發(fā)的優(yōu)化方案實(shí)例
  • PHP優(yōu)化之批量操作MySQL實(shí)例分析
  • 如何使用PHP對(duì)象POPO來(lái)優(yōu)化你的代碼

標(biāo)簽:克拉瑪依 柳州 六安 唐山 鷹潭 鶴崗 遼陽(yáng) 白城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php優(yōu)化查詢(xún)foreach代碼實(shí)例講解》,本文關(guān)鍵詞  php,優(yōu)化,查詢(xún),foreach,代碼,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php優(yōu)化查詢(xún)foreach代碼實(shí)例講解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于php優(yōu)化查詢(xún)foreach代碼實(shí)例講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章