Django中的Model(表结构)

Model(表设计)

在这里只提经常用到的三种联表结构:

  • 一对多:models.ForeignKey(其他表)
  • 多对多:models.ManyToManyField(其他表)
  • 一对一:models.OneToOneField(其他表)

一、联表结构一对多

一对多:当一张表中创建一行数据时,有一个单选的下拉框(可以被重复选择)
例如:创建用户信息时候,需要选择一个用户类型【普通用户】【金牌用户】【铂金用户】等。文章地址https://www.yii666.com/article/756269.html

Django中的Model(表结构)网址:yii666.com

先来看django  models里面是怎么写的:

 class Color(models.Model):

     name = models.CharField(max_length=15)

 class Someting(models.Model):

     c1 = models.CharField(max_length=15)
c2 = models.CharField(max_length=15)
c3 = models.CharField(max_length=15)
c4 = models.CharField(max_length=15)
color = models.ForeignKey(Color) #设置外键为另一个类名
13 class Host(models.Model):
16 hostname = models.CharField(max_length=15)
business = models.ForeignKey('Business') #用引号的方式是避免外键的类在下面而导致的报错 class Business(models.Model):
21 name = models.CharField(max_length=15)

在数据库中的两张表,可以看到设置外键的那列关联到了另一张表上的id列:

color表:

Django中的Model(表结构)

something表:

Django中的Model(表结构)

同样也可以有选择性的关联另一张表中的数据:

参数:to_field=“”

 class Shoplist(models.Model):

     name = models.CharField(max_length=15, null=True, unique=True)   #必须要设置unique = True,(不能重复)
price = models.CharField(max_length=15) class Shop(models.Model): v1 = models.CharField(max_length=15)
v2 = models.CharField(max_length=15)
pr = models.ForeignKey(Shoplist, to_field='name')

二、联表结构多对多

一张图诠释了多对多的含义:

Django中的Model(表结构)

在django中的models里:

 class Group(models.Model):

     groupname = models.CharField(max_length=15)

 class User(models.Model):

     name = models.CharField(max_length=15)
email = models.CharField(max_length=15)
phone = models.CharField(max_length=15)
group = models.ManyToManyField(Group) #与表Group创建多对多的关联

在这里我们不需要专门创建第三张关联的表,django自动就为我们创建了第三张表:

Django中的Model(表结构)

三、联表结构一对一

django中的一对一表结构可以理解为在多对多的基础上建立的,只不过绑定的表对象里的数据只能出现一次:文章来源地址:https://www.yii666.com/article/756269.html

Django中的Model(表结构)文章来源地址https://www.yii666.com/article/756269.html

由上图理解,表A与表B建立了一对一的结构。(B建立了与A的一对一),那么表A中的数据在表B中只能出现一次。网址:yii666.com<

在django的model里:

 class User2(models.Model):

     name = models.CharField(max_length=15)
email = models.CharField(max_length=15)
phone = models.CharField(max_length=15) class Group2(models.Model): groupname = models.CharField(max_length=15)
group = models.OneToOneField(User2)

版权声明:本文内容来源于网络,版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。文本页已经标记具体来源原文地址,请点击原文查看来源网址,站内文章以及资源内容站长不承诺其正确性,如侵犯了您的权益,请联系站长如有侵权请联系站长,将立刻删除

Django中的Model(表结构)-相关文章

  1. Django中的Model(表结构)

  2. EF5修改edmx表结构保存后不自动更新tt (转)

  3. [转载]github在线更改mysql表结构工具gh-ost

    GitHub正式宣布以开源的方式发布gh-ost:GitHub的MySQL无触发器在线更改表定义工具!gh-ost是GitHub最近几个月开发出来的,目的是解决一个经常碰到的问题:不断变化的产品需求会不断要求更改MySQL表结构。gh-ost通过一种影响小、可控制、可审计、操作简单的方案来改变线上表结构

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信图片_20190322181744_03.jpg

微信扫一扫打赏

请作者喝杯咖啡吧~

支付宝扫一扫领取红包,优惠每天领

二维码1

zhifubaohongbao.png

二维码2

zhifubaohongbao2.png