博客
关于我
Django 数据库基础
阅读量:244 次
发布时间:2019-03-01

本文共 2159 字,大约阅读时间需要 7 分钟。

数据库设计是后端系统开发中的重中之重,尤其是在前后端分离的系统中,后端负责数据管理,代码几乎都围绕数据操作展开。虽然我们教程不是专门讲数据库的,但必须讲解常用的数据库表及表之间关系的设计。

目前使用的主要数据库系统都是关系型数据库,如MySQL、Oracle、SQLServer、SQLite等,而MongoDB、Cassandra等则不是关系型数据库。

关系型数据库建立在关系模型基础上,其难点在于表之间的关联关系设计。常见的关联关系有三种:一对多、一对一、多对多。

一对多关系

一对多关系是通过外键关联实现的。以BYSMS系统为例,客户表(Customer)和订单表(Order)之间是一对多的关系。具体来说,一个客户可以有多个订单,但一个订单只能属于一个客户。

class Customer(models.Model):    name = models.CharField(max_length=200)    phonenumber = models.CharField(max_length=200)    address = models.CharField(max_length=200)class Medicine(models.Model):    name = models.CharField(max_length=200)    sn = models.CharField(max_length=200)    desc = models.CharField(max_length=200)class Order(models.Model):    name = models.CharField(max_length=200, null=True, blank=True)    create_date = models.DateTimeField(default=datetime.datetime.now)    customer = models.ForeignKey(Customer, on_delete=models.PROTECT)
  • customer字段是外键,指向Customer表的主键。
  • on_delete=models.PROTECT参数设置意味着删除客户记录时,必须先删除与之关联的订单记录。

一对一关系

一对一关系可以通过OneToOneField模型字段实现。例如,学生表和地址表之间是一对一的关系,一个学生对应一条地址。

class Student(models.Model):    name = models.CharField(max_length=200)    classname = models.CharField(max_length=200)    desc = models.CharField(max_length=200)class ContactAddress(models.Model):    student = models.OneToOneField(Student, on_delete=models.PROTECT)    homeaddress = models.CharField(max_length=200)    phone = models.CharField(max_length=200)
  • student字段是外键,指向Student表的主键。
  • Django会在migrate时为该字段添加unique=True约束,确保每个学生对应唯一一条地址记录。

多对多关系

多对多关系需要通过中间表来实现。例如,订单表和药品表之间是多对多的关系,可以通过OrderMedicine中间表来关联。

class Order(models.Model):    name = models.CharField(max_length=200, null=True, blank=True)    create_date = models.DateTimeField(default=datetime.datetime.now)    customer = models.ForeignKey(Customer, on_delete=models.PROTECT)    medicines = models.ManyToManyField(Medicine, through='OrderMedicine')class OrderMedicine(models.Model):    order = models.ForeignKey(Order, on_delete=models.PROTECT)    medicine = models.ForeignKey(Medicine, on_delete=models.PROTECT)    amount = models.PositiveIntegerField()
  • medicines字段是ManyToMany字段,通过OrderMedicine中间表关联Medicine表。
  • Django会自动在数据库中创建common_ordermedicine表存储中间记录。

转载地址:http://iamv.baihongyu.com/

你可能感兴趣的文章
pipeline配置与管理Job企业级实战
查看>>
pipeline项目配置实战
查看>>
Pipenv 与 Conda?
查看>>
QVGA/HVGA/WVGA/FWVGA分辨率屏含义及大小//Android虚拟机分辨率
查看>>
pipreqs : 无法将“pipreqs”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径 正确,然后再试一次。
查看>>
pipy国内镜像的网址
查看>>
quiver绘制python语言
查看>>
pip下载缓慢
查看>>
PIP使用SSH从BitBucket安装自定义软件包,无需输入SSH密码
查看>>
pip命令提示unknow or unsupported command install解决方法
查看>>
pip在安装模块时提示Read timed out
查看>>
pip更换源
查看>>
SpringBoot之Banner源码深度分解
查看>>
Pix2Pix如何工作?
查看>>
QuickBI助你成为分析师——搞定数据源
查看>>
pkl来存储python字典
查看>>
quick sort | 快速排序 C++ 实现
查看>>
pkpmbs 建设工程质量监督系统 Ajax_operaFile.aspx 文件读取漏洞复现
查看>>
pkpmbs 建设工程质量监督系统 文件上传漏洞复现
查看>>
pku 2400 Supervisor, Supervisee KM求最小权匹配+DFS回溯解集
查看>>