Django orm详解--组成部件
Django ORM 的核心部件可分为模型系统、查询系统、数据库后端和辅助工具四大类,每个部件负责不同的职责,共同实现对象与关系数据库的映射。以下是核心部件的分层解析:
一、模型系统(Model System)
1. 模型基类(Model Base Class)
- 作用:所有模型类的基类,提供ORM核心功能。
- 核心类:
django.db.models.Model
- 关键特性:
- 通过元类(
ModelBase
)解析模型字段和元数据。 - 自动生成主键字段(
id
)。 - 提供对象级的数据库操作方法(如
save()
、delete()
)。
- 通过元类(
2. 字段类(Field Classes)
- 作用:定义模型字段与数据库列的映射关系。
- 核心类:
- 基础字段:
CharField
、IntegerField
、BooleanField
等。 - 关系字段:
ForeignKey
、ManyToManyField
、OneToOneField
。 - 特殊字段:
DateTimeField
、DecimalField
、FileField
等。
- 基础字段:
- 关键特性:
- 负责数据类型转换(如Python
datetime
→ SQLTIMESTAMP
)。 - 处理字段约束(如
null
、unique
、max_length
)。 - 通过
validators
实现数据验证。
- 负责数据类型转换(如Python
3. 元数据类(Meta Class)
- 作用:定义模型的数据库级元数据。
- 核心属性:
db_table
:指定数据库表名。indexes
:定义索引。ordering
:默认排序规则。unique_together
:联合唯一约束。
- 示例:
class Book(models.Model):class Meta:db_table = "books"indexes = [models.Index(fields=["title"])]
二、查询系统(Query System)
1. 查询集(QuerySet)
- 作用:表示从数据库获取的对象集合,支持链式操作。
- 核心类:
django.db.models.query.QuerySet
- 关键方法:
- 过滤:
filter()
、exclude()
、get()
。 - 排序:
order_by()
、reverse()
。 - 切片:
queryset[0:10]
(不触发SQL)。 - 聚合:
count()
、sum()
、avg()
。
- 过滤:
- 特性:惰性执行,仅在需要数据时生成SQL。
2. 查询表达式树(Query Expression Tree)
- 作用:存储查询条件的抽象语法树。
- 核心类:
django.db.models.sql.Query
- 关键组件:
WhereNode
:表示SQL的WHERE
子句。OrderBy
:表示排序规则。Join
:处理表连接逻辑。
- 示例:
# 表达式树结构:[Filter(author="Doubao"), OrderBy("-price")] Book.objects.filter(author="Doubao").order_by("-price")
3. 查询表达式(Query Expressions)
- 作用:定义复杂查询条件。
- 核心类:
Q()
对象:实现复杂逻辑(如OR条件)。F()
表达式:引用模型字段值(如F('price') * 0.9
)。Func()
表达式:调用数据库函数(如UPPER(title)
)。
- 示例:
from django.db.models import Q, F# 查询价格大于50且作者是Doubao,或价格小于20的书 Book.objects.filter(Q(price__gt=50) & Q(author="Doubao") | Q(price__lt=20))
三、数据库后端(Database Backends)
1. 数据库连接(Database Connection)
- 作用:管理与数据库的物理连接。
- 核心类:
django.db.backends.*.base.DatabaseWrapper
- 支持的数据库:
- PostgreSQL:
django.db.backends.postgresql
- MySQL:
django.db.backends.mysql
- SQLite:
django.db.backends.sqlite3
- Oracle:
django.db.backends.oracle
- PostgreSQL:
- 配置示例:
DATABASES = {'default': {'ENGINE': 'django.db.backends.postgresql','NAME': 'mydatabase','USER': 'mydatabaseuser','PASSWORD': 'mypassword',} }
2. SQL 编译器(SQL Compiler)
- 作用:将查询表达式树转换为数据库特定的SQL。
- 核心类:
django.db.backends.*.compiler.SQLCompiler
- 关键方法:
as_sql()
:生成SQL语句和参数。execute_sql()
:执行SQL并返回结果。
- 示例:
# Python 查询 Book.objects.filter(author="Doubao")# PostgreSQL 生成的 SQL SELECT "books"."id", "books"."title", "books"."author" FROM "books" WHERE "books"."author" = 'Doubao';
3. 模式生成器(Schema Editor)
- 作用:根据模型定义生成数据库模式(表、索引、约束)。
- 核心类:
django.db.backends.*.schema.BaseDatabaseSchemaEditor
- 关键方法:
create_model()
:创建表。alter_field()
:修改字段。delete_model()
:删除表。
四、辅助工具(Utility Components)
1. 事务管理器(Transaction Management)
- 作用:管理数据库事务。
- 核心类:
django.db.transaction.atomic
- 使用方式:
from django.db import transactionwith transaction.atomic():Book.objects.create(title="New Book")# 嵌套事务with transaction.atomic():Book.objects.filter(price__lt=10).delete()
2. 数据库路由器(Database Router)
- 作用:实现多数据库的路由策略。
- 核心接口:
django.db.router.BaseRouter
- 示例配置:
class MyRouter:def db_for_read(self, model, **hints):if model._meta.app_label == 'analytics':return 'analytics_db'return 'default'
3. 迁移系统(Migrations)
- 作用:管理数据库模式变更。
- 核心组件:
makemigrations
:生成迁移文件。migrate
:执行迁移。Migration
类:表示一次模式变更。
- 迁移文件示例:
class Migration(migrations.Migration):dependencies = [('myapp', '0001_initial')]operations = [migrations.AddField(model_name='book',name='is_published',field=models.BooleanField(default=False),),]
五、核心部件协作流程
- 模型定义:开发者定义继承自
Model
的类,声明字段和元数据。 - 查询构建:通过
objects
管理器创建QuerySet
,添加过滤、排序条件。 - SQL 生成:
Query
对象将查询条件转换为表达式树,由SQLCompiler
生成SQL。 - 数据库交互:
DatabaseWrapper
建立连接,执行SQL并获取结果。 - 结果映射:将数据库行数据转换为模型对象或值列表。
相关文章:
Django orm详解--组成部件
Django ORM 的核心部件可分为模型系统、查询系统、数据库后端和辅助工具四大类,每个部件负责不同的职责,共同实现对象与关系数据库的映射。以下是核心部件的分层解析: 一、模型系统(Model System) 1. 模型基类&#…...

Tomcat 使用与配置全解
一、 Tomcat简介 Tomcat服务器是Apache的一个开源免费的Web容器。它实现了JavaEE平台下部分技术规范,属于轻量级应用服务器。 1. Tomcat版本 Tomcat版本 JDK版本 Servlet版本 JSP版本 10.0.X 8 and later 5.0 3.0 9.0.x 8 and later 4.0 2.3 8.0.x 7…...
Chrome 开发中的任务调度与线程模型实战指南
内容 概述 快速入门指南 核心概念线程词典 线程任务优先使用序列而不是物理线程 发布并行任务 直接发布到线程池通过 TaskRunner 发布 发布顺序任务 发布到新序列发布到当前(虚拟)主题 使用序列代替锁将多个任务发布到同一线程 发布到浏览器进程中的主线…...

aws instance store 的恢复
1: aws instance store 要在launch instance 才可以创建,而且,通过snapshot 恢复后,instance store 里面的数据会丢失。 下面是创建instance store 的过程,和通过两种方式恢复,发现/etc/fstab 不同的写法,有的不能启动: [root@ip-xx ~]# lsblk NAME MAJ:MIN RM …...
从零开始创建 Vue 3 开发环境并构建第一个 Demo
Vue 3 是目前前端开发中非常流行的渐进式 JavaScript 框架。本文将手把手带你完成从环境搭建到运行一个基础 Vue 3 示例的全过程。 📦 一、环境准备 1. 安装 Node.js Vue 项目依赖 Node.js 运行环境,请确保你的电脑已安装 Node.js(建议使用…...

EasyRTC音视频实时通话助力微信小程序:打造低延迟、高可靠的VoIP端到端呼叫解决方案
一、方案概述 在数字化通信浪潮下,端到端实时音视频能力成为刚需。依托庞大用户生态的微信小程序,是实现此类功能的优质载体。基于WebRTC的EasyRTC音视频SDK,为小程序VoIP呼叫提供轻量化解决方案,通过技术优化实现低延迟通信&a…...

STM32 SPI通信(软件)
一、SPI简介 SPI(Serial Peripheral Interface)是由Motorola公司开发的一种通用数据总线四根通信线:SCK(Serial Clock)、MOSI(Master Output Slave Input)、MISO(Master Input Slav…...

每日刷题c++
快速幂 #include <iostream> using namespace std; #define int long long int power(int a, int b, int p) {int ans 1;while (b){if (b % 2){ans * a;ans % p; // 随时取模}a * a;a % p; // 随时取模b / 2;}return ans; } signed main() {int a, b, p;cin >> a …...
(自用)Java学习-5.19(地址管理,三级联动,预支付)
1. 地址管理模块 地址展示 前端:通过 showAddress() 发起 Ajax GET 请求,动态渲染地址列表表格,使用 #{tag}、#{name} 等占位符替换真实数据。 后端: 控制器层调用 AddressService,通过 AddressMapper 查询用户地址数…...
【容器】docker使用问题处理
问题一、systemctl start docker启动报 ERROR: ZONE_CONFLICT: docker0 already bound to a zone 处理方法 firewall-cmd --permanent --zonedocker --change-interfacedocker0 systemctl restart firewalld 问题二、启动容器报 ptables failed/iptables: No chain/target/…...

ChemDraw 2023|Win英文|化学结构编辑器|安装教程
软件下载 【名称】:ChemDraw 2023 【大小】:1.34G 【语言】:英文界面 【安装环境】:Win10/Win11 【夸克网盘下载链接】(务必手机注册): https://pan.quark.cn/s/320bcb67da80 【网站下载…...
Vue3实现提示文字组件
Vue3 实现一个文字提示组件(Tooltip) 文字提示(Tooltip)是前端开发中非常常见的组件,通常用于在用户悬停某个元素时显示额外的信息。 一、需求分析 我们要实现一个 Vue3 的文字提示组件,具备以下功能&…...
JAVA与C语言之间的差异(一)
一、代码习惯以及主函数 JAVA中{在使用的时候不要换行 public static void main(String[] args) {int[] array {1, 2, 3};for(int i 0; i < array.length; i){System.out.println(array[i] " ");}} 其次,以main函数为主函数: public …...
深入剖析 C 语言中的指针数组与数组指针
资料合集下载链接: https://pan.quark.cn/s/472bbdfcd014 在C语言中,指针是其强大和灵活性的核心。然而,围绕指针的概念有很多容易混淆的地方,其中“指针数组”和“数组指针”就是一对常见的“双胞胎”概念。它们名称相似,但含义和用法却大相径庭。 本文旨在清…...

4.1.1 Spark SQL概述
Spark SQL是Apache Spark的一个模块,专门用于处理结构化数据。它引入了DataFrame这一编程抽象,DataFrame是带有Schema信息的分布式数据集合,类似于关系型数据库中的表。用户可以通过SQL、DataFrames API和Datasets API三种方式操作结构化数据…...
【VSCode-Qt】Docker远程连接的项目UI文件在 VSCode 上无法预览
Docker远程连接的UI文件在 VSCode 上无法预览,通常是因为 VSCode 通过远程开发扩展(Remote - SSH/Docker)连接到 Docker 容器时,某些图形化功能未正确配置或支持。以下是可能原因和解决方案: 原因分析 X11 转发未配置…...

redis五种数据结构详解(java实现对应的案例)
一、简述 Redis是一款高性能的键值对存储数据库,它支持五种基本数据类型,分别是字符串(String)、列表(List)、哈希(Hash)、集合(Set)、有序集合(Sorted Set)。 二、五种基本数据类型 2.1 字符串(String) String是Redis最基本的类型,一个key对…...
Telnet 命令详解
Telnet 命令详解:从基础到实战应用 Telnet 是一种历史悠久的网络协议,广泛用于远程登录和管理设备。尽管如今更安全的 SSH 协议已逐渐取代其地位,但 Telnet 在特定场景下依然发挥着重要作用。本文将深入解析 Telnet 命令的参数、使用场景及注…...
深度解析新能源汽车结构与工作原理
一、核心系统架构 新能源汽车主要由三大核心系统构成: 电力驱动系统:包含永磁同步电机、电机控制器(MCU)及减速器,采用三合一集成设计实现轻量化。永磁同步电机通过电磁感应原理将电能转化为机械能,其效率可…...

React 生命周期与 Hook:从原理到实战全解析
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 持续学习,不断…...
OpenSSL 与 C++ 搭建一个支持 TLS 1.3 的服务器
好的,我们可以使用 OpenSSL 与 C 搭建一个支持 TLS 1.3 的服务器。下面是: ✅ 一、完整示例代码(基于 OpenSSL) 使用 C 和 OpenSSL 创建一个简单的 TCP TLS 服务器,支持 TLS 1.3。 ✅ 代码:tls_server.cp…...
HOW - 简历和求职面试宝典(六)
文章目录 1. 如何更好地认识自己?一、认清自己的实力二、明确求职方向三、认识求职岗位与自己的匹配度2. 如何判断公司是否合适自己?一、网站平台二、内部人员三、通过面试官1. 如何更好地认识自己? 一、认清自己的实力 我们经常会听到这样的话:我现在的工作做的好不开心…...

【机器学习基础】机器学习入门核心算法:逻辑回归(Logistic Regression)
机器学习入门核心算法:逻辑回归(Logistic Regression) 一、算法逻辑1.1 基本概念1.2 Sigmoid函数1.3 决策边界 二、算法原理与数学推导2.1 概率建模2.2 损失函数推导2.3 梯度下降优化2.4 正则化处理 三、模型评估3.1 常用评估指标3.2 ROC曲线…...
深入理解设计模式之命令模式
下面是一篇关于设计模式之命令模式(Command Pattern)的详细博客,并附有 Java 实现代码示例。 深入理解设计模式之:命令模式(Command Pattern) 一、什么是命令模式? 命令模式(Comma…...

智能仓储落地:机器人如何通过自动化减少仓库操作失误?
仓库作业的速度和准确性至关重要,尤其是在当前对无差错、高效作业的要求达到前所未有的环境下。每一个错误,无论是物品放错位置还是库存差异,都会在供应链中产生连锁反应,造成延误、增加成本,并最终影响客户满意度。 …...
Android 架构演进之路:从 MVC 到 MVI,拥抱单向数据流的革命
在移动应用开发的世界里,架构模式的演进从未停歇。从早期的 MVC 到后来的 MVP、MVVM,每一次变革都在尝试解决前一代架构的痛点。而今天,我们将探讨一种全新的架构模式 ——MVI(Model-View-Intent),它借鉴了…...

[低代码表单生成器设计基础]ElementUI中Layout布局属性Form表单属性详解
Layout 布局 ElementUI 的 Layout 布局系统基于 24 栏栅格设计,提供了灵活的响应式布局能力,适用于各种页面结构的构建。(CSDN) 📐 基础布局结构 ElementUI 的布局由 <el-row>(行)和 <el-col>࿰…...
数据结构7——二叉树
一、二叉树的定义与性质 1.定义 首先是树形结构,每个节点最多有2棵树,二叉树的子树有左右之分,不能颠倒。 2.性质 (1)二叉树的第i层,最多有2的(i-1)次幂。 (2)深度为k࿰…...

从“被动养老”到“主动健康管理”:平台如何重构代际关系?
在老龄化与数字化交织的背景下,代际关系的重构已成为破解养老难题的关键。 传统家庭养老模式中,代际互动多表现为单向的“赡养-被赡养”关系。 而智慧养老平台的介入,通过技术赋能、资源整合与情感连接,正在推动代际关系向“协作…...
Java 中的 synchronized 和 Lock:如何保证线程安全
Java 中的 synchronized 和 Lock:如何保证线程安全 引言 在 Java 多线程编程中,线程安全是一个核心问题。当多个线程同时访问共享资源时,可能会导致数据不一致或其他不可预期的结果。synchronized关键字和Lock接口是 Java 中实现线程同步的…...