在我的应用程序中,我需要将User
与user-selected-filename
一个用户只能选择一个文件名,但同一个文件名可能被多个用户选择
所以,数据库表可能是这样的
auth_user(创建者django.contrib.auth
)
-----------------------------------------
id | username | first_name | last_name | ...
------------------------------------------
1 | bert | bert | russel |...
------------------------------------------
2 | jon | jon | snow | ...
-------------------------------------------
3 | alice | alice | tanner | ...
用户文件表
-----------------------------------------------
id | filename
------------------------------------------------
1 | '/clips/summary.mp4'
------------------------------------------------
2 | '/clips/intro.mp4'
------------------------------------------------
user_userfile 表
-----------------------------------
user_id | userfile_id
-----------------------------------
1 | 1
-----------------------------------
2 | 1
-----------------------------------
3 | 2
-----------------------------------
好像userfile--user
是有1 - n
关系的。1 个用户文件可以与多个用户关联。
那么,我应该用什么来表示这种关系呢?在下面给出的 UserFile 类中,如果我使用
user = db.models.ForeignKey(django.contrib.auth.User)
那只会产生相反的关系(即n-1
for userfile--user
)
class UserFile(db.models.Model):
filename = db.models.CharField()
user = ??