0

タグにリンクされたビデオデータベースに取り組んでいます。このクエリを実行すると、長時間待つ必要があり、一時テーブルなどが作成されますが、これはより高速な方法である必要があると思います:

EXPLAIN SELECT SQL_NO_CACHE  `video_id` 
FROM  `video_tag_link` 
WHERE  `tag_id` 
IN (
'2752',  '36370'
)
GROUP BY  `video_id` 
HAVING COUNT(  `video_id` ) =2
LIMIT 0 , 20

MySQL Result: 1
SIMPLE
video_tag_link
range
PRIMARY,video_id
PRIMARY
4
NULL
300268
Using where; Using index; Using temporary; Using filesort

Mysql table
CREATE TABLE IF NOT EXISTS `video_tag_link` (
  `video_id` int(10) unsigned NOT NULL,
  `tag_id` int(10) unsigned NOT NULL,
  PRIMARY KEY (`tag_id`,`video_id`),
  KEY `video_id` (`video_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

Total of 45mil records in this table.

このクエリを手伝ってくれる人はいますか?

4

1 に答える 1

0

タグIDを整数として試してもらえますか

EXPLAIN SELECT SQL_NO_CACHE  `video_id` 
FROM  `video_tag_link` 
WHERE  `tag_id` 
**IN (2752,  36370)**
GROUP BY  `video_id` 
HAVING COUNT(  `video_id` ) =2
LIMIT 0 , 20
于 2015-06-21T09:17:00.253 に答える