用户退出群后 是用一个状态标记好 还是直接删除用户记录好

105 天前
 broli7753

三张表 用来实现群组功能

CREATE TABLE `group` (
  `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '群 ID',
  `type` tinyint unsigned NOT NULL DEFAULT '1' COMMENT '群类型[1:普通群;2:企业群;]',
  `name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '' COMMENT '群名称',
  PRIMARY KEY (`id`), 
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='群';


CREATE TABLE `group_apply` (
  `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增 ID',
  `group_id` int unsigned NOT NULL DEFAULT '0' COMMENT '群组 ID',
  `user_id` int unsigned NOT NULL DEFAULT '0' COMMENT '用户 ID',
  `status` int NOT NULL DEFAULT '1' COMMENT '申请状态',
  `updated_at` datetime NOT NULL COMMENT '更新时间',
  PRIMARY KEY (`id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='申请加群表';


CREATE TABLE `group_member` (
  `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增 ID',
  `group_id` int unsigned NOT NULL DEFAULT '0' COMMENT '群组 ID',
  `user_id` int unsigned NOT NULL DEFAULT '0' COMMENT '用户 ID',
  `leader` tinyint unsigned NOT NULL DEFAULT '0' COMMENT '成员属性[0:普通成员;1:管理员;2:群主;]', 
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='群成员表';

疑问

3272 次点击
所在节点    MySQL
19 条回复
amrom
105 天前
肯定是给一个标记好,考虑到后续的业务,比如,新用户首单优惠这种的,有了标记就可以避免被重复注册薅羊毛
corcre
105 天前
我应该会另开一个表记录退群操作, 然后删除记录
Twnysta
105 天前
可以加一个 history 表
历史用户记录都在里面
mudi
105 天前
标记吧,防止需要恢复,真删就真没了
broli7753
105 天前
标记的弊端就是,一堆脏数据。
fFeeOps
105 天前
@broli7753 #5 开个单独的表来记录
ciki
105 天前
单独做个日志表
lasuar
105 天前
JC:把這個群的歷史成員全都給我調出來,包括退群的,看一下 xx 的發言記錄
WX:好的。
broli7753
105 天前
@fFeeOps
@ciki
@Twnysta

各位佬 也是支持 二楼做法么。 先删除 保持群内成员的准确性, 然后再记录下来 方便后期查看
broli7753
105 天前
@lasuar 这个需求 其实标记更加合适。 只要加入过这个群的。 基本跑不了。
kneo
105 天前
随便。看你现有架构怎么修改方便。
加标记需要你保证每次查询都设置正确的条件,容易出 bug ,也有一定程度性能影响。
kk2syc
105 天前
考虑合规的话就不能避免脏数据,另外开表记录后期也是脏,不如提前规划好条件字段标记匹配,营销活动另外做关联表,间隔一段时间清洗数据、分表操作,旧数据打包封入冷存储备份
buchikoma
105 天前
@broli7753 #5 定期归档就行,这块成本很低
ETiV
105 天前
删了之后,群里这个用户的聊天记录咋显示,不显示昵称、头像什么的了吗?
drymonfidelia
105 天前
单独一个数据库,存档全部操作记录(加群退群改名什么的全要存),线上表直接删除啊
你们都没做过大一点的项目吗
现在查数据 每个用户在哪个时间改成了哪个昵称都要求你能查出来
swulling
105 天前
用历史替代标记
whileFalse
105 天前
@ETiV 难道你会给群用户一个单独的群内 id ?如果还用 uid 有啥关系。
angryfish
105 天前
看自己的需求咯,如果是内部系统,不涉及审计,直接删除。
如果外部用户的,还是做标志吧。日志表挺麻烦的。
broli7753
104 天前
分析了下自己的业务场景,决定用一个状态标记处理。 简单直接, 因为用户量不算大,查询性能也影响不了多少。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1064682

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX