文章詳情頁
mysql - 循環中逐個查詢數據庫和聯表一次性查詢數據庫分別適用于哪種場景?
瀏覽:112日期:2022-06-20 16:31:04
問題描述
一般來說循環中逐條查詢的效率是比較低的,每次都產生連接以及并發的開銷。是否有些場景是適合在循環中逐個去查詢,而不適合一次性查表的場景呢?
問題解答
回答1:不要在循環中去查詢, 看不到任何在適合在循環中查詢的理由!如果你是一個離線任務, 不用像web請求那樣即時返回, 并且數據量也比較大, 那合理的做法也是你對查詢做一定的切割, 每次獲取幾十到幾百的數據(過多的數據也會導致傳輸緩慢)最后, 即使迫不得已真的要在循環中去查詢了, 你也應該使用同一個連接, 而不是每次都重新建立連接!
回答2:有,例如:
SELECT * FROM tableWHERE ...ORDER BY ..LIMIT 10
這種時候如果WHERE條件有若干個(例如id=1,id=2),就只能分開查了。雖然GROUP BY也可以,但GROUP BY在數據量大的時候性能可能比較低,一次GROUP BY查詢的時長可能比分開多次查詢的時間還要長。
相關文章:
1. html5和Flash對抗是什么情況?2. 數據庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。3. ios - 類似微博首頁,一張圖的時候是如何確定圖大小的?4. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)5. javascript - 在ie下為什么會出現這種情況呢 《 無法獲取未定義或 null 引用的屬性“length”》 ?請大神指教。6. javascript - 我是做web前端的,公司最近有一個項目關于數據統計的!7. javascript - 如何使用loadash對[object,object,object]形式的數組進行比較8. css右浮動字的順序顛倒了9. javascript - vue過渡效果 css過渡 類名的先后順序10. javascript - vuejs+elementui 購物車價格計算,點擊加減號修改數量總價都不會改變,但是計算執行了
排行榜
