mysql过滤两个不同字段的sql语句


众所周知,一般在mysql过滤相同记录时常用的关键字是distinct, group by等关键字,但是怎么过滤两个不同的字段相同的记录呢。


以下是问题需求:

有一张表chat_history中存在字段id,from_uid,to_uid等字段,其中id为自增id,from_uid为消息的发送方的uid,to_uid为接收方的uid,现在需要获得某一个uid的最新联系人。


首先的第一个想法就是对from_uid,to_uid进行group by操作然后获得max(id)过滤出from_uid或者to_uid等于目标uid的值。

按照这种想法我们可以获得如下的sql语句


select max(id) as mid,from_uid,to_uid from chat_history where from_uid="xxxxxx" or to_uid = "xxxxxx" group by from_uid, to_uid order by mid.

这时我们查看结果可以很明显的发现一个问题,假设两个相互通信的uid1和uid2,我们通过上面的sql语句获取到两条数据from_uid=uid1,to_uid=uid2和from_uid=uid2,to_uid=uid1。当然这也不是问题,数据我们已经查到了,我们可以通过程序再对结果进行一次合并,我们就可以获得我们希望获得的数据。


在最近联系比较少的情况下,上述的处理方法并没有什么不合适的地方,但是当最近联系人较多时,我们可能会

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值