以下查询的平均持续时间为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
但我不知道如何改进我的查询以获得正确的结果。
答案 0 :(得分:0)
我尝试了另一种解决方案并生成了一个帮助表。我发现找到合成索引的正确顺序非常重要: 1. position应该是“group by”列,在我的例子中是artist_id 2. position应该是我用于“count”的列,这里是master_id 然后是WHERE子句。
在开始时,我对索引使用了相同的列组合,但速度要慢得多。现在我能够在1秒后得到结果,与之前的10秒相比,性能提升了很多。