MySQL - COUNT和ORDER BY在大型表上的性能非常慢

时间:2018-05-03 03:31:24

标签: mysql sql-order-by innodb limit

以下查询的平均持续时间为10秒:

SELECT masters_genres.*, masters_artists.*, 
COUNT(masters_artists.master_id) as quantity FROM masters_genres 
JOIN masters_artists ON masters_genres.master_id = masters_artists.master_id 
WHERE masters_genres.genre='Electronic' GROUP BY masters_artists.artist_id 
ORDER BY quantity DESC LIMIT 25

这些表有2百万和3百万条记录。

表格结构:

-- -----------------------------------------------------
-- Table `music_data`.`masters_artists`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `music_data`.`masters_artists` (
  `master_id` INT(30) NOT NULL,
  `artist_id` INT(30) NOT NULL,
  `artist_name` VARCHAR(500) CHARACTER SET 'utf8' NOT NULL,
  INDEX `artist_id` (`artist_id` ASC),
  INDEX `fk_masters_artists_masters_idx` (`master_id` ASC),
  CONSTRAINT `fk_masters_artists_masters`
    FOREIGN KEY (`master_id`)
    REFERENCES `music_data`.`masters` (`master_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB
DEFAULT CHARACTER SET = latin1;


-- -----------------------------------------------------
-- Table `music_data`.`masters_genres`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `music_data`.`masters_genres` (
  `master_id` INT(30) NOT NULL,
  `genre` VARCHAR(255) CHARACTER SET 'utf8' NOT NULL,
  INDEX `genre` (`genre` ASC),
  INDEX `fk_masters_genres_masters1_idx` (`master_id` ASC),
  CONSTRAINT `fk_masters_genres_masters1`
    FOREIGN KEY (`master_id`)
    REFERENCES `music_data`.`masters` (`master_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB
DEFAULT CHARACTER SET = latin1;

我该怎么做才能加快查询速度? 我知道速度正在下降,因为......

ORDER BY quantity DESC

但我不知道如何改进我的查询以获得正确的结果。

1 个答案:

答案 0 :(得分:0)

我尝试了另一种解决方案并生成了一个帮助表。我发现找到合成索引的正确顺序非常重要: 1. position应该是“group by”列,在我的例子中是artist_id 2. position应该是我用于“count”的列,这里是master_id 然后是WHERE子句。

在开始时,我对索引使用了相同的列组合,但速度要慢得多。现在我能够在1秒后得到结果,与之前的10秒相比,性能提升了很多。