mysql 多个distinct_关于mysql:SQL从多个列中选择DISTINCT值

我希望我制定正确的标题。

我正在尝试为帖子制作标签,例如在instagram中。

用户最多可以添加3个标签。 我将它们分别保存在单独的数据库列中。 (tag1 / tag2 / tag3)及更高版本只想显示不同的值及其总数。 无论它们位于哪一列。

例如我有2个不同的mysql行(帖子)

第1行有:tag1 =房子,tag2 =厨房,tag3 =空

第2行有:tag1 =房屋,tag2 =庭院,tag3 =房屋

我想显示房子(2)/厨房(1)/花园(1)/家庭(1)

我得到的结果是:house(1)/ kitchen(1)/ garden(1)/ home(1)/ house(1),因为每个house都在不同的列中。

我有数据库表(diy_posts):

图片

我的SQL查询的想法:

SELECT DISTINCT p.tag1 as tag1, p.tag2 as tag2, p.tag3 as tag3,

SUM(CASE WHEN p.tag1=tag1 OR p.tag2=tag2 OR p.tag3=tag3 THEN 1 ELSE 0 END) as count FROM diy_posts p GROUP BY p.id

并像这样显示它们:

foreach ($diyTags as $tag) {

echo $tag['tag1']; echo $tag['count'];

echo $tag['tag2']; echo $tag['count'];

echo $tag['tag3']; echo $tag['count'];

}

您可以通过取消透视表来做到这一点:

select tag, count(*)

from ((select p.tag1 as tag from diy_posts p) union all

(select p.tag2 as tag from diy_posts p) union all

(select p.tag3 as tag from diy_posts p)

) pt

group by tag;

需要执行此操作表明您可能没有正确的数据模型。更典型的模型是:

我确实注意到,这确实需要触发器才能将标签的数量限制为三个。这也使数据库可以通过简单地定义唯一的约束或索引来防止重复标签。

谢谢。这可行。可以的时候我会检查它作为答案。如果我理解您的想法正确。它对我没有用。因为想法就像在instagram中一样。每个用户都可以想到自己的标签。因此,可能有数千个。

@ArtisU?janovs。 。那不是问题。实际上,将每个标签存储在单独的行中可能会更好,因此获取标签列表更为简单。

不同的关键字无法实现所需的输出。

同样对于所需的输出,您的Table模式是错误的。它必须是垂直的,而不是水平的。

仍然在现有的Table结构中,您可以通过在ServerSide中进行比较和计数过程来获得所需的输出(您的情况似乎是PHP)。

这就是我猜测要在现有架构中实现输出的唯一方法。

-但是,这会在标记和帖子大小增加时破坏性能,因此您需要更改表架构,也可以使用子表。

为了获得更好的sql性能,最好将所有数据拆分为更多的子表?因为我以前曾经那样。现在,我将所有cms重写为越来越少的结构化数据表。

是的,您可以看到人们建议的其他解决方案。他们必须使用所有3个查询的输出的UNION,因为要进行聚合,如果有大量数据,这从性能的角度来看非常昂贵。因此建议使用子表。

将其变成一列并进行求和:

尽管此代码可以回答问题,但提供有关如何和/或为什么解决问题的其他上下文将改善答案的长期价值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值