首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL word+word搜索

MySQL word+word搜索
EN

Stack Overflow用户
提问于 2011-06-21 21:21:19
回答 4查看 220关注 0票数 0

我有两个表:字典,名字。这两个表都有大量的行(如200.000行)。

字典中的列: id、word

名称中的列: id、名称

我需要选择Dictionary.word+Dictionary.word的所有名称(对于所有变体,类似于同一列的连接)

此外,我需要快速查询,而不是需要几个小时才能加载的东西…关于这个速度-如果对列/词比较的要求设置为“最少5个字符”,我会感到满意……

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-06-21 21:27:51

试试这个:

代码语言:javascript
复制
SELECT * FROM `Names` `n`
INNER JOIN `Dictionary` `d`
ON `d`.`word` IS NOT NULL
AND (`n`.`name` LIKE CONCAT(`d`.`word`,`d`.`word`));

更新:

代码语言:javascript
复制
SELECT * FROM `Names` `n`
INNER JOIN `Dictionary` `d1`
INNER JOIN `Dictionary` `d2`
        ON `n`.`name` = CONCAT(`d1`.`word`,`d2`.`word`) 
        OR `n`.`name` LIKE CONCAT(`d1`.`word`,`_%`) 
        OR `n`.`name` LIKE CONCAT(`d2`.`word`,`_%`)
票数 -1
EN

Stack Overflow用户

发布于 2011-06-21 21:28:54

这应该是可行的:

代码语言:javascript
复制
SELECT `N`.`name`
FROM `Names` `N`
INNER JOIN `Dictionary` `D` ON `N`.`name` = CONCAT(`D`.`word`, `D`.`word`);

新建查询:

代码语言:javascript
复制
SELECT `N`.`name`
FROM `Names` `N`
INNER JOIN `Dictionary` `D`
INNER JOIN `Dictionary` `D1`
WHERE `N`.`name` = CONCAT(`D`.`word`, `D1`.`word`);
票数 1
EN

Stack Overflow用户

发布于 2011-06-21 21:44:00

这将尝试使用d.word上的索引来获取答案。

代码语言:javascript
复制
SELECT *
FROM Names n
JOIN Dictionary d1
JOIN Dictionary d2
WHERE 
    LEFT(n.name, LENGTH(n.name)/2) = d1.word
AND RIGHT(n.name, LENGTH(n.name)/2) = d2.word
AND n.name = CONCAT(d1.word, d2.word);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6425917

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档