Django模型基础

本节先介绍一下Django框架模型的基础知识,主要包括Django模型介绍、Django模型与ORM,以及Django模型与MySQL等方面的内容。

3.1.1  Django模型介绍

Django模型主要用来关联数据库,相当于一个ORM(对象关系映射)系统。Django框架提供了对各种主流数据库很友好的支持,这些数据库包括PostgreSQL、SQLite、MySQL、MariaDB和Oracle等。Django模型为这些数据库提供了统一的API调用接口,设计人员可以直接根据项目业务需求选择不同的数据库。Django模型包含了储存数据的字段与行为,一般每个模型都会映射一张数据库表。

Django框架与数据库相关的代码一般写在models.py文件中,相关的配置信息在settings.py文件中完成即可(可参看第2章的内容)。将配置信息写在settings.py文件中的好处是,models.py文件只负责关注业务代码即可,无须关心具体的数据库类型。

3.1.2  Django模型与ORM

ORM(Object Relational Mapping,对象关系映射)是一种程序设计与软件工程技术。ORM可以用于在面向对象编程中实现不同类型系统之间的数据转换。

ORM从功能上来讲,相当于实现了一个在编程语言中可以使用的“虚拟对象数据库”。此时,ORM就相当于一个中间层的逻辑数据,连接着上层的编程语言与底层的实体数据库。

Django模型设计了自己的ORM,并基于Python语言实现。Django模型在业务逻辑层和实体数据库之间充当着桥梁的作用,通过使用描述对象和实体数据库之间的映射的元数据,将程序中的对象自动持久化到实体数据库中。

在Django官方文档中,关于Django模型有如下的说法:

  • 一个Django模型相当于一个Python的类,该类继承自django.db.models.Model。
  • Django模型类的每个属性都相当于一个数据库的字段。
  • Django模型为设计人员自动生成访问数据库的API。

3.1.3  Django模型与MySQL

MySQL是Web应用开发中比较常用的关系数据库,这里我们就以MySQL数据库为例,详细介绍在Django模型中使用数据库的方法。另外,如果读者还没有使用过MySQL数据库,就要花一些时间先熟悉一下MySQL。

如果想在Django模型中使用MySQL数据库,就需要先安装Python语言解释器下的MySQL客户端驱动。MySQL客户端驱动有很多种,这里选择pymysql驱动。安装时需要使用pip工具,具体命令如下:

python –m pip install pymysql

安装过程中如果出现问题,就耐心多试几次。安装完成后,命令行会给出“安装成功”的提示信息,如图3.1所示。这里安装的pymysql版本是1.1.0,该版本是当前的最新版。

为了进一步验证pymysql驱动已经成功安装,可以使用pip list命令查看一下Python的第三方插件列表,具体如图3.2所示。

插件列表中给出的版本号与图3.1中的是一致的,证明pymysql驱动确实已经安装成功了。

其实,除了pymysql驱动之外,还有一个mysqlclient驱动也非常受欢迎。安装mysqlclient驱动会相对麻烦一些,在线安装经常会出问题。不过,我们也可以将mysqlclient驱动包下载到本地进行安装,具体如图3.3所示。提示信息显示mysqlclient驱动安装已经成功了,相应的版本号为2.2.1。

关于pymysql驱动和mysqlclient驱动:pymysql驱动是由纯Python语言编写的,因此与Python解释器契合程度最好;而mysqlclient驱动的执行速度很快,性能优势很明显。

文节选自《Django 5企业级Web应用开发实战(视频教学版)》,获出版社和作者授权发布。

相关推荐

  1. Django 模型基础(五)

    2024-04-14 08:06:03       38 阅读
  2. Django模型

    2024-04-14 08:06:03       33 阅读
  3. Django模型

    2024-04-14 08:06:03       20 阅读
  4. Django模板

    2024-04-14 08:06:03       33 阅读
  5. Django——模板

    2024-04-14 08:06:03       23 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-14 08:06:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-14 08:06:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-14 08:06:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-14 08:06:03       20 阅读

热门阅读

  1. 【应急响应篇】钓鱼邮件应急响应指南

    2024-04-14 08:06:03       18 阅读
  2. 24、Lua 学习笔记之二(进阶话题)

    2024-04-14 08:06:03       22 阅读
  3. docker shell安装

    2024-04-14 08:06:03       18 阅读
  4. 【初学】前后端flask+vue组合GET案例

    2024-04-14 08:06:03       16 阅读
  5. docker安装es和kibana

    2024-04-14 08:06:03       22 阅读
  6. insert statements with append hint in archive log

    2024-04-14 08:06:03       17 阅读
  7. 设计模式(018)行为型之策略模式

    2024-04-14 08:06:03       49 阅读
  8. cocos2dx4.0 vs编译报错

    2024-04-14 08:06:03       17 阅读