LEFT JOIN 上的数据库规范化?
Posted
技术标签:
【中文标题】LEFT JOIN 上的数据库规范化?【英文标题】:Database Normalization on LEFT JOIN? 【发布时间】:2015-07-21 03:42:55 【问题描述】:我想通过一个查询将我所有的帖子标签加载到 mysql 服务器中。现在,我决定使用 LEFT JOIN,因为如果没有标签与我的帖子相关联,那么我也会有那个帖子,或者您对此有任何其他建议?这是我的问题:
SELECT * FROM tags, tags_map
LEFT JOIN posts on posts.cid = tags_map.pid
WHERE tags.tag_id = tags_map.tid
现在的问题是重复数据,例如如果一个帖子有三个标签,那么帖子本身会重复三次! 在这种情况下,我应该为每个帖子运行另一个查询以获得它们的标签吗?还是我可以通过一个查询获得所有这些但没有重复数据?
【问题讨论】:
提供表的 DDL。 请提供您从 sql 获得的结果。 【参考方案1】:我想你想要group_concat
SELECT posts.*,
(select GROUP_CONCAT(tags.name)
from tags,
tags_map
LEFT JOIN on posts.cid = tags_map.pid
WHERE tags.tag_id = tags_map.tid) as tagCombo
from posts
如果您发布架构、示例数据和预期结果,最好是作为 SQLFiddle,我可以检查。
【讨论】:
以上是关于LEFT JOIN 上的数据库规范化?的主要内容,如果未能解决你的问题,请参考以下文章
我厚吗? MySQL:LEFT JOIN 上的“不是唯一的表/别名”
R语言配对图可视化:pivot_longer函数将宽格式的数据重塑为长格式并进行数据全连接和左连接(left join)配对图可视化(根据分类变量的值为散点图上的数据点添加颜色)