mysql concat 去掉重复_mysql concat 唯一键 count distinct 去重

一、背景

事情是这样的:需求要求按月的时间维度统计商品的被咨询情况,但咨询量需要按天去重的,即一个会员一天内向客服小姐姐放了N次商品链接,商品咨询量只能算一次

二、未去重的情况

第一次做的时候,是按月的维度,直接统计商品的被咨询次数

SELECTmsg_month,

goods_code,COUNT(*) ASsend_countFROMim_single_msg_detailWHEREmsg_monthBETWEEN 202007

AND 202009

GROUP BYmsg_month,

goods_codeORDER BYmsg_monthASC,

send_countDESCLIMIT0,10

后来产品说不太符合他们的要求,发现有一些用户一天会给客服发送10几20次商品链接,这样不去重的统计被咨询次数就没有什么意义不了,不方便他们做商品被咨询排行和咨询转化率(转化为订单的概率)

三、利用 concat 来拼接唯一键,再用 count distinct 来统计咨询量

要求:同一天内同一用户向客服发送同一个商品的链接,不管发送几次都只算一次咨询量

也就是说:concat(msg_date,member_code,goods_code) 一样的时候,不管出现几次都只算一次,即:distinct concat(msg_date,member_code,goods_code)

SELECTmsg_month,

goods_code,COUNT(DISTINCTCONCAT(

msg_date,

member_code,

goods_code

)

)ASsend_countFROMim_single_msg_detailWHEREmsg_monthBETWEEN 202007

AND 202009

GROUP BYmsg_month,

goods_codeORDER BYmsg_monthASC,

send_countDESCLIMIT0,10

注:一直都不知道还用 distinct concat 这种用法,今天发现这个,还蛮神奇的~

完。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值