我有这个疑问SQL数据库索引设计内加入关键字搜索
SELECT a.*
FROM entries a
INNER JOIN entries_keywords b ON a.id = b.entry_id
INNER JOIN keywords c ON b.keyword_id = c.id
WHERE c.key IN ('wake', 'up')
GROUP BY a.id
HAVING COUNT(*) = 2
,但它的速度慢。我如何优化设计索引以加快速度?
编辑 这是当前模式
CREATE TABLE `entries` (`id` integer PRIMARY KEY AUTOINCREMENT, `sha` text);
CREATE TABLE `entries_keywords` (`id` integer PRIMARY KEY AUTOINCREMENT, `entry_id` integer REFERENCES `entries`, `keyword_id` integer REFERENCES `keywords`);
CREATE TABLE `keywords` (`id` integer PRIMARY KEY AUTOINCREMENT, `key` string);
CREATE INDEX `entries_keywords_entry_id_index` ON `entries_keywords` (`entry_id`);
CREATE INDEX `entries_keywords_entry_id_keyword_id_index` ON `entries_keywords` (`entry_id`, `keyword_id`);
CREATE INDEX `entries_keywords_keyword_id_index` ON `entries_keywords` (`keyword_id`);
CREATE INDEX `keywords_key_index` ON `keywords` (`key`);
我使用SQLITE3,查询不会失败,但速度很慢。
现在我这样的查询(子查询为每个关键字):
select *
from (
select *
from (entries) e
inner join entries_keywords ek on e.id = ek.entry_id
inner join keywords k on ek.keyword_id = k.id
where k.key = 'wake') e
inner join entries_keywords ek on e.id = ek.entry_id
inner join keywords k on ek.keyword_id = k.id
where k.key = 'up';
这是方式更快,但感觉不对,因为它会变得丑陋,如果我有很多的关键字。
你现在有什么指标? – Taryn
引用列上的索引将有所帮助。缓慢的部分可能是最后一点..计数*对于性能不是很好。我假设这是mysql,但如果它是另一个数据库,你可以使用keywords.key的部分索引作为优化。 –
'keywords.key'编入索引吗? –