文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Django中ORM基本应用与原理解析

2024-04-02 19:55

关注

1.ORM构建数据表

由于每一个数据表对应一个Model定义,每一个Model都是一个Python类,所以,Model之间是可以继承的。Django规定,所有的Model都必须继承自django.db.models.Model

Model中的所有字段都是django.db.models.Field的子类,Django会根据Field的类型确定数据库表的字段类型

首先定义定义抽象Model基类:

class BaseModel(models.Model):
    class Meta:
        # 抽象类,表现为BaseModel不会创建数据表
        abstract = True
        # 按照创建时间逆序排序
        ordering = ['-created_time']

    # 定义了两个类属性:created_time和last_modified,且都是DateTimeField类型
    # auto_now_add用于将首次创建对象时间设置为当前时间
    # auto_now用于将每次保存对象时间设置为当前时间
    created_time = models.DateTimeField(auto_now_add=True, help_text=u'创建时间')
    last_modified = models.DateTimeField(auto_now=True, help_text=u'修改时间')

    # 优化打印(print)Model实例的样式
    def __str__(self):
        raise NotImplementedError

由于BaseModel直接继承自django.db.models.Model,所以,我们创建的实体数据表可以继承自Base Model,从而实现间接继承

例如:话题表

class Topic(BaseModel):
    title = models.CharField(max_length=255, unique=True, help_text=u'话题标题')
    content = models.TextField(help_text=u'话题内容')
    is_online = models.BooleanField(default=True, help_text=u'话题是否在线')
    user = models.ForeignKey(to=User, to_field='id', on_delete=models.CASCADE, help_text=u'关联用户表')

    def __str__(self):
        return '%d:%s' % (self.id, self.title[0:20])

Topic中除了基本类型的字段定义之外,还包含了一个外键(ForeignKey)引用的user字段

评论表:

class Comment(BaseModel):
    content = models.CharField(max_length=255, help_text=u'话题评论')
    topic = models.ForeignKey(to=Topic, to_field='id', on_delete=models.CASCADE, help_text=u'关联话题表')
    up = models.IntegerField(default=0, help_text=u'支持')
    down = models.IntegerField(default=0, help_text=u'反对')

    def __str__(self):
        return '%d:%s' % (self.id, self.content[0:20])

2.数据迁移

首先,在settings.py文件中添加此Model视图的app:(post.apps.PostConfig

INSTALLED_APPS = [
    'post.apps.PostConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

生成迁移文件:

python manage.py makemigrations post

执行migrate命令将Models映射为数据库的表:

python manage.py migrate

生成的表结构:

3.Model相关的概念与使用方法

Model的组成部分

每个Model都是一个Python类,且通常会包含四个部分:继承自django.db.models.Model、Model元数据声明(Meta内部类)、若干个Field类型的字段以及__str__方法

Meta元数据类属性说明

Meta类用于定义Model的元数据,即不属于Model的字段,但是可以用来标识它的一些属性

abstract:

一个布尔类型的变量,如果设置为True,则标识当前的Model是抽象基类,这个元选项不具有传递性,只对当前声明的类有效。例如,对于之前定义的BaseModel,用abstract声明为抽象基类,但是子类Topic和Comment不受影响

db_table:

这个字段用于指定数据表的名称

默认会使用Django的表名生成规则,例如Topic会映射到post_topic表。如果想让Topic映射到topic表,定义db_table='topic'即可

ordering:

用于指定获取对象列表时的排序规则

按照created_time逆序排序,可以定义:

ordering = ['-created_time']

先按照created_time逆序排序,再按照last_modified正序排序:

ordering = ['-created_time', 'last_modified']

indexes:

它是一个列表类型的元选项,用来定义Model的索引

unique_together:

标识联合唯一约束,在数据库层面表现为联合唯一索引

Field的通用字段选项

blank:

对于任何一个属性,默认是不允许输入空值的,如果允许这种情况发生,需要设置blank=True

unique:

如果一个字段设置了unique=True,则表示唯一性索引

null:

规定这个字段的数据是否可以是空值

db_index:

如果该字段经常作为查询的条件,那么就需要考虑设置db_index选项,以加快数据的检索速度

default:

用于给字段设置默认值

choices:

设置了choices的字段在管理后台的显示上会由文本框变成选择框,选择框中的可选值就是choices中的元组

help_text:

这个选项用于在表单中显示字段的提示信息。例如在管理后台的编辑页面,对应在字段输入框的下方会显示该选项设定的值

基础字段类型

关系字段类型

多对一

实例:

user = models.ForeignKey(to=User, to_field='id', on_delete=models.CASCADE, help_text=u'关联用户表')

to:指定所关联的Model

on_delete:当删除关联表的数据时,Django将根据这个参数设定的值确定应该执行什么样的SQL约束

一对一

实例:

user = models.OneToOneField(to=User, on_delete=models.CASCADE, parent_link=False,
                             help_text=u'关联用户表')

多对多关系类型

实例:

books = models.ManyToManyField(to=Book)

到此这篇关于Django ORM基本应用与原理剖析的文章就介绍到这了,更多相关Django ORM原理内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯