如何加入两个级联的多对多关系?
我有5张表:
ITEMS : id / name
ITEMS_TAXONOMIES : id / item_id / taxonomy_id
TAXONOMIES : id / attribute_id / adjective_id
ATTRIBUTES : id / name
ADJECTIVES : id / name我需要一次SELECT来检索特定项目的所有相关属性-形容词对。
我正在使用Sphinx搜索引擎,我需要寻找与项目相关联的单词。
谢谢你的提示...
发布于 2012-09-27 01:14:04
(我已经在狮身人面像论坛上做了回答)
我认为最简单的解决方案是
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中。
https://stackoverflow.com/questions/12589788
复制相似问题