django框架模型层功能、组成与用法分析

Django框架模型层功能、组成与用法分析

1. 模型层的作用

Django框架采用了MVC模式,其中模型层是其核心部分。它的作用是连接数据库、处理数据和提供数据的接口。模型层相当于应用程序和数据库管理系统之间的中间层,它负责与数据库进行交互,提供了支持存储和检索数据的常用方法,例如添加、删除、修改和查询数据记录等。

2. 模型层的组成

模型层由模型类管理器查询集三个部分组成。

2.1 模型类

模型类是指定义数据模型的Python类,它是Django模型层的核心概念。模型类通过继承django.db.models.Model类来定义数据库表的结构和字段,从而把数据存储到数据库中。

from django.db import models

class Student(models.Model):
    name = models.CharField(max_length=50)
    age = models.IntegerField()

上面的代码定义了一个名为Student的模型类,它有nameage两个字段,分别为CharFieldIntegerField类型。这个模型类在数据库中对应的表名为appname_student,其中appname为应用程序的名称,由Django自动根据模型类的名称生成。

2.2 管理器

管理器是模型类的一个属性,它提供了模型类与数据库交互的接口。如果没有指定一个管理器,Django将自动为模型类创建一个名为objects的管理器。

class Student(models.Model):
    name = models.CharField(max_length=50)
    age = models.IntegerField()

    # 自定义管理器
    objects = models.Manager()

在上面的代码中,我们将默认的objects管理器重命名为StudentManager

class StudentManager(models.Manager):
    def get_students(self, **kwargs):
        return self.filter(**kwargs)

class Student(models.Model):
    name = models.CharField(max_length=50)
    age = models.IntegerField()

    objects = StudentManager()

2.3 查询集

查询集是管理器返回的对象,它包含了符合特定查询条件的模型对象集合。查询集也支持链式调用,可以对查询条件、排序、范围、聚合等操作进行组合。

students = Student.objects.filter(age__gte=18).exclude(name__startswith='A').order_by('-age')

上面的代码中,我们使用filter()方法过滤出年龄大于等于18岁,且姓名不以字母“A”开头的所有学生。然后使用exclude()方法排除这些学生中的姓名以字母“A”开头的。最后使用order_by()方法对学生按照年龄倒序排序。

3. Django模型层的用法分析

3.1 创建模型

创建模型需要按照以下步骤进行:

  • models.py文件中定义模型类,继承django.db.models.Model类;
  • 在模型类中定义字段。
# models.py
from django.db import models

class Student(models.Model):
    name = models.CharField(max_length=50)
    age = models.IntegerField()

3.2 构建数据库表结构

使用以下命令进行数据库迁移。

python manage.py makemigrations # 生成迁移文件
python manage.py migrate # 执行迁移操作

3.3 数据库操作

3.3.1 插入数据

# 创建模型对象,并保存到数据库中
student = Student(name="Tom", age=20)
student.save()

# 批量创建多个模型对象
students = [
    Student(name="Tom", age=20),
    Student(name="Jack", age=21),
]
Student.objects.bulk_create(students)

3.3.2 查询数据

# 查询所有学生对象
students = Student.objects.all()

# 查询学生姓名为"Tom"的学生对象
student = Student.objects.filter(name="Tom").first()

# 查询年龄小于等于20的学生对象
students = Student.objects.filter(age__lte=20)

# 查询年龄大于等于18岁,且姓名不以字母“A”开头的学生对象
students = Student.objects.filter(age__gte=18).exclude(name__startswith='A')

# 对查询结果进行排序,按照年龄从小到大排序
students = Student.objects.order_by('age')

# 对查询结果进行反向排序,按照年龄从大到小排序
students = Student.objects.order_by('-age')

# 统计学生对象个数
count = Student.objects.count()

3.3.3 更新数据

# 修改某个学生对象的姓名和年龄
student = Student.objects.get(id=1)
student.name = "Tommy"
student.age = 21
student.save()

# 批量修改学生对象的年龄为20
Student.objects.filter(name="Tom").update(age=20)

3.3.4 删除数据

# 删除某个学生对象
student = Student.objects.get(id=1)
student.delete()

# 删除所有学生对象
Student.objects.all().delete()

4. 示例说明

4.1 一个简单的博客系统

下面是一个简单的博客系统,它包含了博客、分类和标签三个模型。每个博客可以属于一个分类,也可以有多个标签。

# models.py
from django.db import models

class Category(models.Model):
    name = models.CharField(max_length=50)

class Tag(models.Model):
    name = models.CharField(max_length=50)

class Blog(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    created_time = models.DateTimeField(auto_now_add=True)
    modified_time = models.DateTimeField(auto_now=True)
    category = models.ForeignKey(Category, on_delete=models.CASCADE)
    tags = models.ManyToManyField(Tag)

上面的代码中,我们定义了CategoryTagBlog三个模型类。其中,Blog模型使用了ForeignKeyManyToManyField这两个字段类型。

ForeignKey字段用来定义外键,它表示一个模型实例与另一个模型实例之间的关系。在Blog模型中,我们定义了category字段,它与Category模型中的一个实例关联。

ManyToManyField字段用来定义多对多关系,它表示一个模型实例可以有多个与之相关的另一个模型实例。在Blog模型中,我们定义了tags字段,它与Tag模型中的多个实例关联。

4.2 一个简单的投票系统

下面是一个简单的投票系统,它包含了投票、选项和结果三个模型。每个投票可以有多个选项,每个选项又可以属于多个投票,结果统计了每个选项的投票数量和占比。

# models.py
from django.db import models

class Vote(models.Model):
    name = models.CharField(max_length=50)
    start_time = models.DateTimeField()
    end_time = models.DateTimeField()
    create_time = models.DateTimeField(auto_now_add=True)

class Option(models.Model):
    name = models.CharField(max_length=50)
    vote = models.ManyToManyField(Vote)

class Result(models.Model):
    option = models.ForeignKey(Option, on_delete=models.CASCADE)
    num = models.IntegerField()
    ratio = models.FloatField()

上面的代码中,我们定义了VoteOptionResult三个模型类。其中,VoteOption之间是多对多关系,中间需要一个辅助模型来存储该关系;Result模型与Option模型之间是一对多关系。

模型的使用方法基本相同,只需按照模型的定义使用增、删、改、查等操作即可。例如,查询所有Vote模型的实例:

votes = Vote.objects.all()

5. 总结

Django模型层是Django框架的核心部分之一,它负责连接数据库、处理数据和提供数据的接口。模型层由模型类、管理器和查询集三个部分组成,它们共同构建了整个数据模型的框架。模型层的使用方法并不难,只需要按照模型的定义使用增、删、改、查等操作即可。在实际应用中,我们需要充分利用Django模型层的功能和组成,选择合适的方法操作数据库,以提高开发效率和代码可维护性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:django框架模型层功能、组成与用法分析 - Python技术站

(0)
上一篇 2023年5月16日
下一篇 2023年5月16日

相关文章

  • Django用户身份验证完成示例代码

    关于Django用户身份验证完成示例代码,我们可以大概分为以下两个部分进行讲解: 认证机制设置 在开始编写代码前,我们需要先在Django工程下设置好认证机制。具体做法如下: (1)在settings.py文件中找到INSTALLED_APPS(已安装应用列表)这个配置项,在其中添加django.contrib.auth模块。 (2)在settings.py…

    Django 2023年5月16日
    00
  • Django数据查询中对字段进行排序 Django数据查询中对字段进行排序

      第一种方法:使用order_by进行排序 Articlelist = Article.objects.filter(**kwargs).order_by(‘nid’) Articlelist = Article.objects.filter(**kwargs).order_by(‘-nid’) #倒序 Articlelist = Article.obje…

    Django 2023年4月13日
    00
  • Web框架Django(二)

    到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 import MySQLdb def GetList(sql): db = MySQLdb.connect(user=’root’, db=’wupeiqidb…

    Django 2023年4月16日
    00
  • Django-利用paginator模块实现分页

    Django专门提供了一个paginator模块,实现分页很easy。 下面的例子引用了django官方文档:https://docs.djangoproject.com/en/1.11/topics/pagination/ Paginator实例化需要2个参数,一个是待分页的对象list(需要实现count方法或者__len__方法),另一个是每页数量。 …

    Django 2023年4月10日
    00
  • django项目实现应用系统的自动更新

    需求:有多个应用系统部署在不同的WINDOWS机器上,应用通过IIS对外发布,并且同一个应用都有在多台机器上面实现负载均衡,每次应用发布更新手工处理不仅效率低,还存在一定的误操作的风险,为提高工作效率,使用DJANGO发布的站点对各个应用实现自动更新 1、应用系统信息的表结构 models.py class systeminfo(models.Model):…

    Django 2023年4月16日
    00
  • 在Python的Django框架中更新数据库数据的方法

    在Python的Django框架中,更新数据库数据的主要方法有两种: 1. 使用查询集更新数据 我们可以使用查询集(QuerySet)操作数据库,对数据进行修改,然后使用 save() 方法保存到数据库中。 例如,如果我们想将一个 User 对象的 username 属性修改为 “new_username”,可以按照以下的步骤进行: 先根据 id 或者其他条…

    Django 2023年5月15日
    00
  • Django ORM那些相关操作

    必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。 <4> exclude(**kwa…

    Django 2023年4月11日
    00
  • 在Django中创建动态视图的教程

    下面是在Django中创建动态视图的完整攻略: 1. 在urls.py中配置动态视图的路径 首先要在项目的urls.py中配置动态视图的路径。在urls.py文件中添加以下代码: from django.urls import path from . import views urlpatterns = [ path(‘dynamic/’, views.dy…

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