Django models中的增删改查与MySQL SQL的对应关系

在 Django 中,models 提供了一种高层次的抽象来与数据库进行交互,使得开发者可以使用 Python 代码而非直接编写 SQL 来执行增删改查(CRUD)操作。下面将详细介绍 Django 的 ORM(对象关系映射)操作如何对应到 MySQL 的 SQL 查询。

创建 (Create)

Django Models:

python 复制代码
# 创建并保存一个新对象
new_entry = MyModel(field1='value1', field2='value2')
new_entry.save()

MySQL SQL:

sql 复制代码
INSERT INTO myapp_mymodel (field1, field2) VALUES ('value1', 'value2');

读取 (Read)

获取单个对象

Django Models:

python 复制代码
# 根据主键获取一个对象
entry = MyModel.objects.get(id=1)

MySQL SQL:

sql 复制代码
SELECT * FROM myapp_mymodel WHERE id = 1;
获取多个对象

Django Models:

python 复制代码
# 获取所有对象
entries = MyModel.objects.all()

# 使用过滤条件获取对象
filtered_entries = MyModel.objects.filter(field1='value1')

MySQL SQL:

sql 复制代码
-- 获取所有对象
SELECT * FROM myapp_mymodel;

-- 使用 WHERE 子句过滤
SELECT * FROM myapp_mymodel WHERE field1 = 'value1';
聚合查询

Django Models:

python 复制代码
from django.db.models import Count

# 统计总数
count = MyModel.objects.count()

# 分组统计
grouped = MyModel.objects.values('field1').annotate(count=Count('id'))

MySQL SQL:

sql 复制代码
-- 统计总数
SELECT COUNT(*) FROM myapp_mymodel;

-- 分组统计
SELECT field1, COUNT(id) AS count FROM myapp_mymodel GROUP BY field1;

更新 (Update)

Django Models:

python 复制代码
# 更新单个对象
entry = MyModel.objects.get(id=1)
entry.field1 = 'new_value'
entry.save()

# 批量更新
MyModel.objects.filter(field1='old_value').update(field1='new_value')

MySQL SQL:

sql 复制代码
-- 更新单个对象
UPDATE myapp_mymodel SET field1 = 'new_value' WHERE id = 1;

-- 批量更新
UPDATE myapp_mymodel SET field1 = 'new_value' WHERE field1 = 'old_value';

删除 (Delete)

Django Models:

python 复制代码
# 删除单个对象
entry = MyModel.objects.get(id=1)
entry.delete()

# 批量删除
MyModel.objects.filter(field1='value1').delete()

MySQL SQL:

sql 复制代码
-- 删除单个对象
DELETE FROM myapp_mymodel WHERE id = 1;

-- 批量删除
DELETE FROM myapp_mymodel WHERE field1 = 'value1';

高级查询

Django 的 ORM 还支持更复杂的查询,例如联合查询、子查询等,这些都可以通过 Django 的 Q 对象和 F 表达式来实现。对于非常复杂的查询,如果 ORM 不足以满足需求,Django 还允许直接执行原始 SQL 查询:

python 复制代码
from django.db import connection

def custom_sql(query, params=None):
    with connection.cursor() as cursor:
        cursor.execute(query, params)
        return cursor.fetchall()

这使得您可以根据需要灵活地选择是使用 ORM 抽象还是直接编写 SQL 查询。

总之,Django 的 ORM 提供了一个强大而灵活的方式来与数据库交互,简化了数据访问层的开发工作,并且自动处理了许多底层细节,如事务管理、连接池等。同时,它也保持了足够的灵活性,以应对复杂的查询需求。

相关推荐
天海华兮9 小时前
MySQL知识点 覆盖索引、MVCC、存储引擎、事务锁、性能优化等核心点
mysql·事务·日志·索引·mvcc·存储引擎·执行计划
Wait....9 小时前
MySQL底层知识总结
数据库·mysql
DolphinScheduler社区10 小时前
实战演示 | 基于 Apache DolphinScheduler 与 Apache SeaTunnel 实现 MySQL 到 Doris 离线定时增量同步
数据库·mysql·开源·apache·海豚调度·大数据工作流调度
承渊政道10 小时前
【MySQL数据库学习】MySQL基本查询(下)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
摇滚侠10 小时前
Spring 零基础入门到进阶 基于注解的声明式事务 65-70
数据库·mysql·spring
这个人需要休息10 小时前
优惠卷类型漏洞---优惠卷的并发使用
mysql·网络安全·逻辑漏洞·后端架构
小二·10 小时前
MySQL 8.0 性能优化与索引原理
android·mysql·性能优化
AC赳赳老秦10 小时前
OpenClaw + 华为云自动化:批量管理云资源、生成月度云账单分析与成本优化报告
java·开发语言·javascript·人工智能·python·mysql·openclaw
我是一颗柠檬10 小时前
【Java项目技术亮点】读写分离+主从延迟处理:MySQL高并发下的性能优化方案
java·分布式·mysql·性能优化
霸道流氓气质10 小时前
MySQL 大数据量场景下的表结构与索引设计指南
数据库·mysql