一、表與表關系
一對多
多對多
一對一
?
圖書表
出版社
作者表
作者詳情表
出版社?和 圖書表 關系 一對多 外鍵字段在多的一方 book
圖書表 和 作者表 關系 多對多 需要創建第三張表
作者表 和 作者詳情表 關系 一對一
?
#創建表關系 先將基表創建 再添加外鍵字段
一對多
publisher = models.ForeignKey(to="Publisher")
#默認與主鍵關聯
#定義foreignkey 不需要加"_id"
多對多
#多對多,orm自動創建表。
#外鍵字段在任意一方均可,推薦查詢頻率較高的一方。
#不需要"_id"class Author(models.Model):id = models.AutoField(primary_key=True)name = models.CharField(max_length=16, null=False, unique=True)# 告訴ORM 我這張表和book表是多對多的關聯關系,ORM自動幫我生成了第三張表book = models.ManyToManyField(to="Book")
一對一
author_detail=models.OneToOneField(to='AuthorDetail')
#與多對多類似#不需要"_id"
?
二、字段補充
DataField
DataTimeField
??? auto_now:每次操作數據的時候,該字段會自動將當前時間更新
???? auto_now_add:創建數據的時候會自動將當前時間記錄下來,之后只要人人為修改,那么一直不變
?
?
?
?