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应用开发实战(视频教学版)》,获出版社和作者授权发布。

相关推荐
214396515 分钟前
SQL注入防御技术方案_基于正则表达式的输入清洗
jvm·数据库·python
2401_8323655223 分钟前
SQL窗口函数与递归查询的区别_如何根据场景选择
jvm·数据库·python
u01091476023 分钟前
c++如何处理文件路径中由于不规范的连续斜杠导致的路径解析错误【避坑】
jvm·数据库·python
2301_7965885025 分钟前
PHP源码开发用二手硬件划算吗_性价比与稳定性权衡【操作】
jvm·数据库·python
2301_7751481526 分钟前
如何通过C#读取Oracle数据库中的图片显示到WinForm_BLOB转Byte[]与流处理
jvm·数据库·python
小饕28 分钟前
RAG学习之- RAG 数据导入完整指南
人工智能·python·学习
Ulyanov31 分钟前
《玩转QT Designer Studio:从设计到实战》 QT Designer Studio数据绑定与表达式系统深度解析
开发语言·python·qt
weixin_568996061 小时前
mysql如何配置大页内存_mysql large-pages开启方法
jvm·数据库·python
HHHHH1010HHHHH1 小时前
HTML怎么创建评论区域_HTML嵌套评论语义结构【详解】
jvm·数据库·python
Absurd5871 小时前
C#怎么模拟键盘按键输入_C#如何实现自动化脚本【教程】
jvm·数据库·python