优化MySql InnoDB数据库中的慢查询

时间:2011-02-10 14:09:21

标签: mysql optimization innodb acid

我有一个MySql数据库,其查询运行速度非常慢。我正在尽我所能让它表现得更好但却看不出我在这里做错了什么。也许你可以吗?

CREATE TABLE `tablea` (
    `a` int(11) NOT NULL auto_increment,
    `d` mediumint(9) default NULL,
    `c` int(11) default NULL,
    PRIMARY KEY  (`a`),
    KEY `d` USING BTREE (`d`)
) ENGINE=InnoDB AUTO_INCREMENT=1867710 DEFAULT CHARSET=utf8;

CREATE TABLE `tableb` (
    `b` int(11) NOT NULL auto_increment,
    `d` mediumint(9) default '1',
    `c` int(10) NOT NULL,
    `e` mediumint(9) default NULL,
    PRIMARY KEY  (`b`),
    KEY `c` (`c`),
    KEY `d` (`d`),
) ENGINE=InnoDB AUTO_INCREMENT=848150 DEFAULT CHARSET=utf8;

查询:

SELECT tablea.a, tableb.e
FROM tablea
INNER JOIN tableb ON (tablea.c=tableb.c) AND (tablea.d=tableb.d OR tableb.d=1)
WHERE tablea.d=100

如果tablea.d = 100给出1500行并且(tablea.d = tableb.d或tableb.d = 1)给出1600行,则此查询需要10秒才能运行。这看起来真的很慢。我需要让它快得多,但我看不出我做错了什么。

MySql EXPLAIN输出:

id   select_type table   type   possible_keys key key_len ref       rows  Extra
1    SIMPLE      tablea  ref    d             d   4       const     1092  Using where
1    SIMPLE      tableb  ref    c,d           c   4       tablea.c  1     Using where

1 个答案:

答案 0 :(得分:0)

如果我不对OR感到困惑,则查询等同于:

SELECT tablea.a, tableb.e
FROM tablea
  INNER JOIN tableb
    ON  tablea.c = tableb.c 
WHERE tablea.d = 100
  AND tableb.d IN (1,100) 

尝试使用各种索引(使用EXPLAIN)。 d字段(在两个表中)的索引会有所帮助。或许更多,(d,c)上的索引。