如何高效实现多用户通知系统而不造成数据库冗余

本文介绍一种基于关系型数据库的轻量级通知系统设计,通过分离"通知模板"与"用户状态"两张表,避免消息重复存储,支持全局广播、已读标记及高并发写入。 本文介绍一种基于关系型数据库的轻量级通知系统设计,通过分离"通知模板"与"用户状态"两张表,避免消息重复存储,支持全局广播、已读标记及高并发写入。在构建面向多用户的 Web 通知系统时,一个常见误区是为每位用户单独插入一条完整通知记录(如标题、内容、时间等),这不仅浪费存储空间,更会随用户量增长导致数据急剧膨胀、查询变慢、维护困难。正确的做法是采用"一对多"范式解耦:将通知内容本身抽象为独立实体,再通过关联表记录每个用户对该通知的交互状态。? 推荐数据库结构设计-- 1. notifications 表:仅存通知元数据(不重复)CREATE TABLE notifications ( id INT PRIMARY KEY AUTO_INCREMENT, title VARCHAR(255) NOT NULL, content TEXT NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, is_active TINYINT(1) DEFAULT 1 -- 支持后台下架旧通知);-- 2. user_notifications 表:记录用户-通知关系与状态CREATE TABLE user_notifications ( id BIGINT PRIMARY KEY AUTO_INCREMENT, notification_id INT NOT NULL, user_id INT NOT NULL, is_read TINYINT(1) DEFAULT 0, read_at DATETIME NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, UNIQUE KEY uk_user_notif (user_id, notification_id), -- 防止重复关联 FOREIGN KEY (notification_id) REFERENCES notifications(id) ON DELETE CASCADE, FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE);? 关键设计说明: notifications 表每条记录代表一条逻辑通知(例如:"系统将于明日维护"),无论有多少用户接收,只存一次; user_notifications 表则为每个用户对每条通知生成一条状态记录,仅含外键、读取标记和时间戳,体积极小; UNIQUE KEY uk_user_notif 是核心约束,防止同一用户被重复关联同一条通知,保障数据一致性。? 后台发送通知的正确流程(PHP 示例)当管理员在后台发布一条新通知时,应执行 原子化两步操作: Mokker AI AI产品图添加背景

相关推荐
顾林海3 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱6 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils7 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽10 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波11 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码11 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱20 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵1 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户0332126663671 天前
使用 Python 从零创建 Word 文档
python