好的,在以下查询中,DMSNODE具有144K行。并且有关于CHANGEDON,ID,PARENT ID的索引以及3个中的2个排列

SELECT
    DISTINCT t0.ID AS a1,
    t0.CHANGEDON,
    t1.id AS a2
FROM
    DMSNODE t0
    LEFT OUTER JOIN DMSNODE t1 ON (t1.ID = t0.PARENT_ID)
ORDER BY
    t0.CHANGEDON ASC
LIMIT
     0, 5


这是表的定义

CREATE TABLE `dmsnode` (
    `ID` BIGINT(20) NOT NULL,
    `PARENT_ID` BIGINT(20) DEFAULT NULL,
    `TITLE` VARCHAR(1024) NOT NULL,
    `CHANGEDON` DATETIME NOT NULL,

    PRIMARY KEY (`ID`),
    KEY `DMSNODE_PARENT_ID_FK` (`PARENT_ID`),
    KEY `DMSNODE_CHANGEDON_IDX` (`CHANGEDON`),
    KEY `idx_dmsnode_ID_PARENT_ID_CHANGEDON` (`ID` , `PARENT_ID` , `CHANGEDON`),
    KEY `idx_dmsnode_ID_PARENT_ID` (`ID` , `PARENT_ID`),

    CONSTRAINT `DMSNODE_FOLDER_ID_FK` FOREIGN KEY (`PARENT_ID`)
        REFERENCES `dmsnode` (`ID`),
    )  ENGINE=INNODB DEFAULT CHARSET=UTF8 COMMENT='DMS Node'


并且EXPLAIN显示全表扫描

id  select_type table   type    possible_keys   key key_len ref rows    Extra
1   SIMPLE      t0      index   ""idx_dmsnode_ID_PARENT_ID_CHANGEDON    25  ""  144982  Using index; Using temporary; Using filesort
1   SIMPLE      t1      eq_ref  PRIMARY,idx_dmsnode_ID_PARENT_ID_CHANGEDON,idx_dmsnode_ID_PARENT_ID PRIMARY 8   tbibms.t0.PARENT_ID 1   Using index


有人可以解释为什么执行全表扫描以及如何避免进行全表扫描吗?我认为使用CHANGEDON上的索引就足以首先选择前5个changeon行,然后进行左外部联接

最佳答案

您的查询中没有WHERE子句,因此数据库引擎必须查看这两个表中的每一行。在这种情况下,与使用索引相比,全表扫描将导致更少的I / O。

分享并享受。

10-08 13:33