# 原创,转载请留言联系

  • 一对多模型

一对多的关系,例如员工跟部门。一个部门有多个员工。那么在django怎么建立这种表关系呢?

其实就是利用外键,在多的一方,字段指定外键即可。例如员工和部门,员工是多,所以在员工表直接部门即可。

示例(见19行):

 class Department(models.Model):
name = models.CharField(max_length=20)
create_data = models.DateField(auto_now_add=True)
is_delete = models.BooleanField(default=False) class Meta:
db_table = "department" class Employee(models.Model):
name = models.CharField(max_length=20)
age = models.IntegerField()
gender = models.IntegerField(default=0)
# decimal_place = 2表示两位小数,max_digits表示8个数字,包括小数的两位
salary = models.DecimalField(max_digits=8,decimal_places=2)
# null=True 表示可以为空,blank=True表示django后台管理输入这个字段可以为空
comment = models.CharField(max_length=300,null=True,blank=True)
hire_data = models.DateField(auto_now_add=True)
department = models.ForeignKey("Department")

class Meta:
db_table = "employee"

拓展:

还有一个需要特别注意:

一对多的查询:

  • 多对多模型

多对多的关系,例如学生与社团。一个学生可以进多个社团,一个社团可以有多个学生。那么在django怎么建立这种表关系呢?

django建立多对多关系有两种方法。

方法一:

 class Student(models.Model):
name= models.CharField(max_length=16)
birthday=models.DateField()
class Club(models.Model):
name= models.CharField(max_length=16)
members = models.ManyToManyField("Student")

只需要在任意一方加上类似第6行的ManyToManyField就可以了。Django会自动为多对多关联关系创建一张表,用于两张表的联系。

那么查询呢?

方法二:(比较灵活)

自己手动建立一张表关联联系。

class Student(models.Model):
name= models.CharField(max_length=16)
birthday=models.DateField() class Club(models.Model):
name= models.CharField(max_length=16) class Membership(models.Model):
student = models.ForeignKey("Student")
club = models.ForeignKey("Club")

那么这种方式建表怎么查询呢?

  • 自关联模型

自关联模型,就是表中的某一列,关联了这个表中的另外一列。最典型的自关联模型就是地区表。省、市、县都在一张表里面。省的pid为null,市的pid为省的id,县的pid为市的id。

示例:

class Area(models.Model):
name = models.CharField(max_length=20, verbose_name='名称')
# 自关联(特殊的一对多): 生成的字段名 parent_id
parent = models.ForeignKey('self', verbose_name='上级行政区划')
class Meta:
db_table = 'tb_areas'
verbose_name = '行政区划'

那么,怎么查询呢?

如果知道一个市,叫a市,想查他属于什么省。

如果知道一个省,叫a省,想查他有什么市。

05-14 13:41