站内通知核心是用户与系统的轻量异步通信,需闭环实现生成、存储、读取、标记已读、分页展示,依赖notice_template和user_notice两张表,支持参数化模板、按用户隔离、状态管理及健壮渲染。
站内通知本质是“用户与系统之间的轻量异步通信”,不依赖邮件或短信通道,数据完全存在数据库中。关键在于:消息的生成、存储、读取、标记已读、分页展示这五个环节要闭环,且支持按用户隔离和状态管理。
至少需要两张表,避免过度设计:
不建议用一张“notice”主表 + “notice_user_relation”关联表——小项目反而增加复杂度;大项目需推送到多端时再考虑解耦。
不是所有场景都实时发,要区分主动触发和批量补发:
noticeService.sendToUser(userId, "ORDER_CREATED", Map.of("orderNo", "NO2025..."))
@Async 或发到 MQ(如 RabbitMQ),防止通知逻辑拖慢主流程用户侧体验决定功能是否被感知:
SELECT COUNT(*) FROM user_notice WHERE user_id = ? AND is_read = 0,缓存5秒内有效即可user_notice,返回模板内容 + 渲染后文案(后端完成拼接,避免前端解析 JSON)IN (id1,id2,...) 或 WHER
E is_read = 0 批量更新,别单条循环