sql查询 case 进行已读未读消息的处理

您所在的位置:网站首页 qq查看消息是否已读 sql查询 case 进行已读未读消息的处理

sql查询 case 进行已读未读消息的处理

2024-06-26 13:32| 来源: 网络整理| 查看: 265

消息分为系统消息与个人消息。

思路:消息统一发送,用户点击某条消息后生成点击记录,代表已读,通过消息点击记录来区分已读未读。

1、数据库结构

CREATE TABLE `sh_push` ( `id` int(11) NOT NULL AUTO_INCREMENT, `type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '0 系统消息 1 个人消息', `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户id 配合type类型等于1使用', `product_id` int(11) NOT NULL DEFAULT '0' COMMENT '产品ID', `name` varchar(100) NOT NULL COMMENT 'push名称', `describe` varchar(500) NOT NULL COMMENT '描述', `notice` varchar(500) NOT NULL DEFAULT '' COMMENT '通知', `is_send` enum('1','0') NOT NULL DEFAULT '0' COMMENT '发送状态 1为已发送 0为未发送', `state` enum('1','0') DEFAULT '1' COMMENT '状态 1显示 0隐藏', `send_time` varchar(50) DEFAULT '' COMMENT '最后一次发送时间', `create_time` datetime NOT NULL COMMENT '创建时间', `update_time` datetime NOT NULL COMMENT '修改时间', PRIMARY KEY (`id`), KEY `IDX_product_id` (`product_id`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; CREATE TABLE `sh_push_click` ( `id` int(11) NOT NULL AUTO_INCREMENT, `product_id` int(11) NOT NULL DEFAULT '0' COMMENT '产品ID', `channel_id` int(11) NOT NULL DEFAULT '0' COMMENT '渠道编号', `push_id` int(11) NOT NULL DEFAULT '0' COMMENT 'push编号', `member_id` int(11) NOT NULL DEFAULT '0' COMMENT '会员ID', `click_time` datetime NOT NULL COMMENT '点击时间', PRIMARY KEY (`id`), KEY `IDX_MEMBER_ID_PUSH_ID` (`member_id`,`push_id`) USING BTREE, KEY `IDX_MEMBER_ID_PRODUCT_ID` (`member_id`,`product_id`) USING BTREE, KEY `IDX_ME_PU_PR` (`member_id`,`push_id`,`product_id`) USING BTREE, KEY `push_id` (`push_id`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

sql查询语句

select id,name,type,user_id,case when id in(select push_id from sh_push_click where member_id = 1) then 1 else 0 end click_type from sh_push a where type = 0 or user_id = 1;

解释:case when 查询sh_push表中id 是否在记录表sh_push_click中,如果有值记为1 如果没用记为0 给定字段名为 click_type;



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3