本文共 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)
一对一关系可以通过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)
多对多关系需要通过中间表来实现。例如,订单表和药品表之间是多对多的关系,可以通过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()
转载地址:http://iamv.baihongyu.com/