duandang9434 2016-07-13 09:22
浏览 218
已采纳

Php mysql未读用户的消息

I am using a message system inside my application and i want to get the number of unread messages in his profile the schema is as follows

Users table     message

user_id         message_id 
......          sender_id
                receiver id
                text 
                flag

flag where is use to determine whether a user has read a message or not . flag=0 user has not read a message and 1 as read

how to get the number of unread message of a particular user

SELECT message_id, count(*)
FROM message
WHERE flag=0
GROUP BY receiver_id;
  • 写回答

2条回答 默认 最新

  • doucong7963 2016-07-13 09:25
    关注

    You're almost there, try this:

    SELECT receiver_id, count(*) as unread_cnt
    FROM message
    WHERE flag = 0
    AND receiver_id = '$particular_user_id'  // If you want all users, you can comment out this line.
    GROUP BY receiver_id;
    

    Also you can get read count by following:

    SELECT
        receiver_id,
        COUNT(CASE WHEN flag = 0 THEN receiver_id END) as unread_cnt,
        COUNT(CASE WHEN flag = 1 THEN receiver_id END) as read_cnt
    FROM message
    WHERE receiver_id = '$particular_user_id' // If you want all users, you can comment out this line.
    GROUP BY receiver_id;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 AT89C51控制8位八段数码管显示时钟。
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口