首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySql选择多对多(多对多)

MySql选择多对多(多对多)
EN

Stack Overflow用户
提问于 2012-09-26 03:28:55
回答 1查看 251关注 0票数 0

如何加入两个级联的多对多关系?

我有5张表:

代码语言:javascript
复制
ITEMS            : id /     name

ITEMS_TAXONOMIES : id /    item_id    / taxonomy_id

TAXONOMIES       : id /  attribute_id / adjective_id

ATTRIBUTES       : id /     name

ADJECTIVES       : id /     name

我需要一次SELECT来检索特定项目的所有相关属性-形容词对。

我正在使用Sphinx搜索引擎,我需要寻找与项目相关联的单词。

谢谢你的提示...

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-27 01:14:04

(我已经在狮身人面像论坛上做了回答)

我认为最简单的解决方案是

代码语言:javascript
复制
sql_query = SELECT i.id, i.name , \
                    GROUP_CONCAT(CONCAT(at.name,' ',ad.name)) as taxonomies \
                    FROM items i \
                          LEFT JOIN items_taxonomies it ON (i.id = it.item_id) \
                          LEFT JOIN taxonomies t ON (t.id = it.taxonomy_id) \
                          LEFT JOIN attributes at ON (at.id = t.attribute_id) \
                          LEFT JOIN adjectives ad ON (ad.id = t.adjective_id) \
                    GROUP BY i.id \
                    ORDER BY NULL

只是为了搜索你不需要使用sql_attr_multi的单词。通过sql_joined_field进行索引,您可能会获得轻微的性能提升,但上面的方法更简单,所以先尝试一下。或者,您可以将属性和形容词放在单独的字段中。但是上面的好处是可以搜索“属性栏”来获得特定的分类法。

如果希望对结果中的文档进行分组或取回相关分类的列表,可以将taxonomy_id粘贴到MVA中。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12589788

复制
相关文章

相似问题

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