Django数据表关联关系映射

Django框架中的数据表关联关系映射是很重要的一个方面。Django提供了多种数据表关联方式。本篇文章将详细介绍Django中的数据表关联关系映射完整攻略,过程中提供代码示例。

一对一关系

在Django中,一对一关系是通过OneToOneField类型来实现的,如下所示:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=30)

class Contact(models.Model):
    email = models.EmailField()
    person = models.OneToOneField(
        Person,
        on_delete=models.CASCADE,
        primary_key=True,
    )

在上述代码中,Contact模型与Person模型之间是一对一关系,通过OneToOneField类型定义。一个Person模型可以拥有一个Contact模型,而一个Contact模型也只能属于一个Person模型。

一对多关系

在Django中,一对多关系是通过ForeignKey类型来实现的,如下所示:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=30)

class Phone(models.Model):
    number = models.CharField(max_length=20)
    person = models.ForeignKey(Person, on_delete=models.CASCADE)

在上述代码中,Phone模型与Person模型之间是一对多关系,通过ForeignKey类型定义。一个Person模型可以拥有多个Phone模型,而一个Phone模型只能属于一个Person模型。

多对多关系

在Django中,多对多关系是通过ManyToManyField类型来实现的,如下所示:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=30)
    friends = models.ManyToManyField("self")

    def __str__(self):
        return self.name

在上述代码中,Person模型与自身之间是多对多关系,通过ManyToManyField类型定义。一个Person模型可以拥有多个朋友(Person模型),而一个Person模型也可以被多个朋友(Person模型)所拥有。

多表关联

在Django中,多表关联可以通过多个一对多关系、一对一关系或多对多关系来实现。例如,我们可以将一个Person模型与多个Group模型关联,如下所示:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=30)

class Group(models.Model):
    name = models.CharField(max_length=30)
    members = models.ManyToManyField(Person, through='Membership')

class Membership(models.Model):
    person = models.ForeignKey(Person, on_delete=models.CASCADE)
    group = models.ForeignKey(Group, on_delete=models.CASCADE)
    date_joined = models.DateField()
    invite_reason = models.CharField(max_length=64)

在上述代码中,Person模型和Group模型之间是多对多关系,通过ManyToManyField类型定义。Membership模型是自定义的多对多关系中间模型,增加了一些额外的字段。这些额外的字段可以记录加入组的日期、邀请理由等信息。

反向关系

在Django中,我们可以通过定义反向关系来访问与当前模型相关的模型。例如,我们可以访问一个Person模型的所有朋友,如下所示:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=30)
    friends = models.ManyToManyField("self")

    def __str__(self):
        return self.name

p1 = Person.objects.create(name='Alice')
p2 = Person.objects.create(name='Bob')
p3 = Person.objects.create(name='Charlie')
p4 = Person.objects.create(name='Dave')

p1.friends.add(p2)
p1.friends.add(p3)
p2.friends.add(p4)

# 访问p1的所有朋友
p1.friends.all()  # 返回QuerySet,包含p2和p3

# 访问p2的所有朋友
p2.friends.all()  # 返回QuerySet,包含p1和p4

在上述代码中,我们使用了ManyToManyField类型来定义一个Person模型与自身的多对多关系。通过访问这个模型的friends属性,我们可以访问与之相关的其他Person模型。使用反向关系,我们可以访问另一个Person模型的friends属性。

以上就是Django数据表关联关系映射完整攻略的详细介绍,希望对大家有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django数据表关联关系映射 - Python技术站

(0)
上一篇 2023年3月12日
下一篇 2023年3月12日

相关文章

  • Anaconda+django写出第一个web app(三)

    前面我们已经建立了模型Tutorial,也已经可以用Navicat Premium打开数据看查看数据,接下来我们通过建立admin账户来上传数据。 在命令行执行如下命令来创建用户:  python manage.py createsuperuser  然后输入相应的用户名、邮箱和密码,邮箱可随意填写,接下来执行 python manage.py runser…

    Django 2023年4月11日
    00
  • django favicon配置

    其实网站加一个图标,在/static/images/里面放置favicon.ico 1. 直接url里修改 from django.views.generic.base import RedirectView favicon_view = RedirectView.as_view(url=’/static/favicon.ico’, permanent=Tr…

    Django 2023年4月16日
    00
  • django MEDIA_URL MEDIA_ROOT 用法

    参考实例:https://cloud.tencent.com/developer/article/1578874   1.在项目setting中具体配置: MEDIA_URL = ‘/media/’ MEDIA_ROOT = os.path.join(BASE_DIR, ‘media’)   2  在url.py 中配置路由 from bookweb.set…

    Django 2023年4月13日
    00
  • django 框架模型之models常用的Field,及常见错误原因及处理方案。

    1. django 模型models 常用字段          1、models.AutoField          自增列 = int(11)        如果没有的话,默认会生成一个名称为 id 的列        如果要显式的自定义一个自增列,必须设置primary_key=True。   2、models.CharField          …

    Django 2023年4月11日
    00
  • Djang中静态文件配置方法

    在Django中,静态文件(如CSS、JavaScript、图片等)是指不随着页面内容的变化而发生改变的文件。下面将详细讲解在Django中如何配置静态文件。 静态文件配置方法 第一步:在settings.py中设置静态文件路径 在Django项目的settings.py文件中,可以通过STATICFILES_DIRS、STATIC_ROOT、STATIC_…

    Django 2023年5月16日
    00
  • python-django rest framework框架之视图

    视图 :常用 1和4 两种 1. 原始的APIView class IndexView(views.APIView): def get(self, request, *args, **kwargs): user_list = models.UserInfo.objects.all() ser = IndexSerializer(instance=user_l…

    Django 2023年4月11日
    00
  • Django基础——Web框架原理

    所有的web应用的本质就是一个socket服务端,而浏览器就是一个socket客户端; 以前我们自己在电脑上写的socket服务端和客户端的通信,我们知道客户端会向服务端发来什么格式的消息,然后我们用服务端去用相应的格式给接收它,其实两者之间,是靠自己定的一个通信的协议。 而现在客户端是用户的浏览器了,因此还想使浏览器的客户端与服务端进行通信,就必须要遵循H…

    Django 2023年4月11日
    00
  • 使用Django连接Mysql数据库步骤

    当使用Django时,连接Mysql数据库的步骤可以分为以下几步: 步骤1:安装Mysql数据库驱动 在连接Mysql数据库之前,需要确保已经安装了Mysql数据库驱动。常用的Mysql数据库驱动有mysqlclient和PyMySQL,可以根据自己的需要选择其中一种安装。在本示例中,我们将使用mysqlclient。 安装mysqlclient可以使用pi…

    Django 2023年5月16日
    00
合作推广
合作推广
分享本页
返回顶部