Django 模型类的存储结构设计

2019-12-01 11:40:50 +08:00
 dolaxi
用户表
id username password login_log

其中 login_log 记录用户的登录历史信息(登录 IP 登录时间等)
如果不另外建立关联表,要如何存储这些登录历史信息呢?这样设计合理吗
3146 次点击
所在节点    Python
13 条回复
cszeus
2019-12-01 12:21:31 +08:00
另外用一个 login log 表,然后里面加一个 user_id 的 foreign key 吧。
assassins9527
2019-12-01 13:21:11 +08:00
要存储一条还是多条。如果多条就像楼上的加个表,一条就直接存在用户表
dolaxi
2019-12-01 14:41:08 +08:00
@cszeus
@assassins9527
不另外建表不可以吗?我担心多建关联表会是数据库读取压力变大,
所有如果字段内容不多还是想尽量放在一个表的字段里
wuwukai007
2019-12-01 14:47:06 +08:00
redis 也可以
EurekaSeven
2019-12-01 14:51:47 +08:00
@dolaxi 除非你只记录一次 log,否则还是加个表。
wnh3yang
2019-12-01 19:21:19 +08:00
login_log 作为 json 字段吧,每次登录 进行 update 操作。
artandlol
2019-12-01 19:55:54 +08:00
看用户登录频率,如果像你三年 v2 发一帖,还是只记录最后一次登录时间状态就好了,建个表都没问题。否则记录在日志上,或者上面的 redis 使用持久化去记录登录信息也可以
matrix1010
2019-12-01 22:30:12 +08:00
最简单的方法用 text field,直接把新的数据加到后面,然后读取时在 Django 里解析,这样的坏处是没法进行查询,比如过去 3 天有多少人登录。
dolaxi
2019-12-01 22:56:32 +08:00
@artandlol
好扎心的栗子。。。
dolaxi
2019-12-01 22:58:30 +08:00
@matrix1010
网上查来查去,貌似也就这个方法可行了
neoblackcap
2019-12-02 10:15:32 +08:00
担心多建表影响性能,那你可以重写 User 类,Django 官方教程有提供如何重写这个类的说明。不过工程量略大。
xpresslink
2019-12-02 10:55:07 +08:00
通常不这样设计。

应当单独另设计一个日志表用于记录用户行为,登录只是行为的一种。
ID action/operation datetime

这样做的好处是关键业务数据和日志等辅助数据解耦,日志数据定期可以清除掉,做统计分析也方便。
lanshee
2019-12-02 15:03:26 +08:00
同意二楼,看你的需求是都要添加还是更新.添加就关联表,更新就是一个字段.

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

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

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

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

© 2021 V2EX