好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > php優化查詢foreach代碼實例講解

php優化查詢foreach代碼實例講解

熱門標簽:地圖標注平臺怎么給錢注冊 釘釘打卡地圖標注 常州地圖標注服務商 衡水外呼系統平臺 福州人工外呼系統哪家強 安裝電銷外呼系統 百度商鋪地圖標注 注冊400電話申請 新河科技智能外呼系統怎么樣

php代碼優化

應避免在php foreach里面進行sql查詢
以下代碼示例使用了laravel的操作數據庫api,eloquent orm

foreach里面執行兩次sql查詢

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

foreach里面執行一次sql查詢

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

將sql查詢移到foreach外面

上面兩個方法都不可避免的在foreach里面執行了數據庫查詢
**應避免在foreach中執行sql查詢**
此處我的做法是再加一層foreach+if來代替sql查詢
// 本質上是將foreach中的查詢移到外面
// $tmp_data_arr 是存儲在foreach外面執行的數據庫查詢結果
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'];
    }
  }
}

小結

// 返回數據
return $datas;

經過簡單的優化:時間(ms):290 -> 230 -> 180

到此這篇關于php優化查詢foreach代碼實例講解的文章就介紹到這了,更多相關php優化查詢foreach內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 淺談PHP性能優化之php.ini配置
  • 詳解PHP優化巨量關鍵詞的匹配
  • PHP引擎php.ini參數優化深入講解
  • PHP安全配置優化詳解
  • PHP內存溢出優化代碼詳解
  • PHP優化教程之解決嵌套問題
  • PHP解決高并發的優化方案實例
  • PHP優化之批量操作MySQL實例分析
  • 如何使用PHP對象POPO來優化你的代碼

標簽:克拉瑪依 柳州 六安 唐山 鷹潭 鶴崗 遼陽 白城

巨人網絡通訊聲明:本文標題《php優化查詢foreach代碼實例講解》,本文關鍵詞  php,優化,查詢,foreach,代碼,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php優化查詢foreach代碼實例講解》相關的同類信息!
  • 本頁收集關于php優化查詢foreach代碼實例講解的相關信息資訊供網民參考!
  • 推薦文章