文章詳情頁
mysql 數據幾十萬 CPU過高
瀏覽:125日期:2022-06-15 08:12:47
問題描述
一個數據表數據有幾十萬的樣子 在查詢頁面反復的時候 CPU特別高基本爆滿SQl語句select count(*) from emp where catid <> 3 and cid =2; 用戶做分頁數量select * from emp limit 1,10; 本頁顯示的
問題解答
回答1:你這個根本沒有訪問索引,直接讀硬盤數據
回答2:sql 語句 發一下。
回答3:InnoDB是沒有直接保存表的數據總數的,select count(*) from emp;要掃一遍索引,反復查當然要耗CPU。
我的測試表有兩千萬數據,沒緩存時count(*)要15秒,有緩存后也要3秒。
show table status where Name = ’your table name’
可以拿到近似的行數。
回答4:這個可以用延遲關聯查詢(索引覆蓋查詢)
相關文章:
1. node.js - mysql如何通過knex查詢今天和七天內的匯總數據2. mysql 插入數值到特定的列一直失敗3. 360瀏覽器與IE瀏覽器有何區別???4. Python從URL中提取域名5. mysql - 百萬行的表中是否盡量避免使用update等sql語句?6. python - 在使用Pycharm時經常看到如下的樣式,小括號里紅色的部分是什么意思呢?7. javascript - 新浪微博網頁版的字數限制是怎么做的8. 怎么在網頁中設置圖片進行左右滑動9. javascript - 豆瓣的這個自適應是怎么做的?10. javascript - 用jsonp抓取qq音樂總是說回調函數沒有定義
排行榜
