国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql5.6.19下子查詢為什么無法使用索引

2020-01-18 23:08:50
字體:
來源:轉載
供稿:網友

表結構很簡單

CREATE TABLE `oplogs` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT,`kind` varchar(45) NOT NULL DEFAULT '',`op` varchar(100) NOT NULL,`user` varchar(25) NOT NULL DEFAULT '',`ip` varchar(16) NOT NULL DEFAULT '',`updatetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=34896 DEFAULT CHARSET=utf8 ROW_FORMAT=FIXED

結果有34895條

sql查詢語句為:

SELECT a.id,a.kind,a.op,a.user,a.ip,a.updatetime FROM oplogs as a inner join(select id from oplogs where 1 order by id desc limit 0,20) as b using(id)

在5.6.19情況下

用php讀取內容并顯示

首次顯示結果需要3.5秒

但是同樣的配置

在linux 下 5.5.38下

只需要0.7秒左右

很奇怪的情況

然后在5.6下執行了explain 結果如下:

而同樣的數據 explain 結構如下:

比較結果很明顯 主要在于對oplogs進行排序時,rows行變化太大了,一個進行了完整的遍歷,第一個使用了索引,造成差距過大,不過原因尚未找到,有哪位知道呢?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 响水县| 叙永县| 洮南市| 盐亭县| 洛宁县| 陆河县| 交城县| 盘锦市| 清河县| 临邑县| 万载县| 松溪县| 长泰县| 康保县| 栾城县| 同仁县| 淮滨县| 济宁市| 金湖县| 柳河县| 云龙县| 讷河市| 新乡县| 乌恰县| 广东省| 龙海市| 浮梁县| 黄浦区| 客服| 贵南县| 恩施市| 浑源县| 武定县| 石台县| 施甸县| 神农架林区| 蒙阴县| 郸城县| 政和县| 玛曲县| 凌云县|