Django `transaction.atomic()` 完整使用指南

目录

  1. #概述
  2. #基本用法
  3. #事务一致性保障机制
  4. #破坏一致性的常见场景
  5. #高级用法
  6. #最佳实践
  7. #诊断与调试
  8. #附录

概述

transaction.atomic() 是 Django 提供的数据库事务管理工具,用于确保一系列数据库操作要么全部成功提交,要么全部回滚,维护数据的一致性。

基本用法

1. 作为上下文管理器

from django.db import transactiondef view_func(request):with transaction.atomic():# 事务内的操作obj1.save()obj2.save()

2. 作为装饰器

@transaction.atomic
def view_func(request):# 整个函数都在事务中执行obj1.save()obj2.save()

事务一致性保障机制

  • 进入块时:创建保存点或开始新事务
  • 成功退出:提交所有更改
  • 异常退出:自动回滚所有更改
  • 嵌套处理:内层块作为保存点处理

破坏一致性的常见场景

1. 异常处理不当

with transaction.atomic():try:risky_operation()except Exception:logger.error("Error occurred")  # 不重新抛出异常 → 破坏一致性

修复方案

with transaction.atomic():try:risky_operation()except Exception as e:logger.error("Error occurred")raise  # 重新抛出异常

2. 长时间运行事务

with transaction.atomic():process_data()  # 耗时操作update_database()  # 可能因锁超时失败

3. 混合非数据库操作

with transaction.atomic():save_to_db()call_external_api()  # 网络操作save_to_db_again()   # 外部API失败可能导致不一致

4. 多数据库操作

with transaction.atomic():  # 只针对default数据库ModelA.objects.create(...)  # defaultModelB.objects.using('other_db').create(...)  # 不受保护

5. 隔离级别冲突

# 事务1
with transaction.atomic():item = Item.objects.select_for_update().get(pk=1)time.sleep(10)# 事务2 (并发执行)
with transaction.atomic():item = Item.objects.get(pk=1)  # 可能被阻塞或读取过期数据

高级用法

1. 手动保存点控制

with transaction.atomic():a.save()sid = transaction.savepoint()  # 创建保存点try:b.save()except Exception:transaction.savepoint_rollback(sid)  # 回滚到保存点# 可继续其他操作transaction.savepoint_commit(sid)  # 释放保存点

2. 指定数据库

with transaction.atomic(using='replica_db'):ReplicaModel.objects.create(...)

3. 嵌套事务控制

with transaction.atomic():  # 外层事务a.save()try:with transaction.atomic():  # 内层保存点b.save()raise ValueErrorexcept ValueError:pass  # 仅回滚内层c.save()  # 仍会提交

最佳实践

  1. 保持事务简短:只包含必要的数据库操作
  2. 明确异常处理
    • 要么完全处理并确保一致性
    • 要么重新抛出异常
  3. 避免混合操作
    • 不在事务中执行网络/文件IO
    • 不在事务中执行耗时计算
  4. 多数据库处理
    with transaction.atomic(using='default'):with transaction.atomic(using='other_db'):# 跨数据库操作
    
  5. 测试隔离级别:了解数据库的默认隔离级别
  6. 监控长事务:设置数据库长事务警报

诊断与调试

1. 检查事务状态

from django.db import connectionprint(f"In atomic block: {connection.in_atomic_block}")
print(f"Needs rollback: {connection.needs_rollback}")

2. 检查隔离级别(PostgreSQL)

with connection.cursor() as cursor:cursor.execute("SHOW transaction_isolation")print(cursor.fetchone())

3. 日志记录

LOGGING = {'loggers': {'django.db.backends': {'level': 'DEBUG','handlers': ['console'],}}
}

附录

支持的数据库后端

数据库支持级别注意事项
PostgreSQL完全支持建议使用
MySQL/MariaDB支持需使用InnoDB
SQLite支持实际是文件锁
Oracle完全支持-
SQL Server支持需验证隔离级别

事务隔离级别参考

级别脏读不可重复读幻读说明
读未提交可能可能可能最低隔离
读已提交不可能可能可能多数数据库默认
可重复读不可能不可能可能MySQL默认
串行化不可能不可能不可能最高隔离

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/89545.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/89545.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UDP协议的端口161怎么检测连通性

UDP 端口 161 (SNMP) 连通性检测的专业指南 UDP 161 端口是 SNMP (Simple Network Management Protocol) 服务的标准端口。由于其无连接特性,检测需要特殊方法。以下是全面的检测方案: 一、专业检测方法 1. 使用 SNMP 专用工具(推荐&#xff…

进阶数据结构:红黑树

嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…

如何上传github(解决git的时候输入正确的账号密码,但提示认证失败)

如何上传github文件,删除文件 1.重点 GitHub 从 2021 年 8 月 13 日起移除了对密码认证的支持。你需要使用个人访问令牌(Personal Access Token, PAT)或 SSH 密钥来进行认证。 2.生成SSH key 进入设置点击New SSH Key名字随便取,可以自己方便记3.上传文件…

多级缓存架构与热点探测系统核心技术解析

多级缓存架构与热点探测系统核心技术解析 📌 一、多级缓存架构 1. 为什么需要多级缓存? ✅ 本地缓存优势: 🚀 减少网络请求,提升访问性能🌐 分布式系统中天然具有分布式缓存特性⬇️ 有效降低远程缓存&…

iOS 性能监控工具全解析 选择合适的调试方案提升 App 性能

在iOS应用开发中,性能往往是决定用户体验的关键因素之一。用户体验的优劣,不仅取决于功能的实现,还在于流畅度、响应速度、资源消耗等方面的表现。因此,性能监控工具在iOS开发中的重要性不可小觑。 无论是提升应用的启动时间、减少…

C++ :vector的介绍和使用

vector学习时一定要学会查看reference 目录 前言 一、vector基本概念 1.1vector是什么? 1.2内存管理 二、vector的使用 2.1vector的构造 2.2vector iterator 的使用 2.3vector 空间增长问题 2.4vector的元素访问 2.5vector 增删查改 总结 前言 在C编程中&#x…

iOS OC 图片压缩

纯代码,不废话,欢迎copy使用,记得点赞 +(NSData *)imageData:(UIImage *)image maxSize:(int)maxSize{ // 设置最大文件大小(200KB) NSLog(@"执行压缩方案 期望压缩目标%dk",maxSize); return [self compressImage:image toMaxSize:maxSize]; } // 主压缩方…

如何更改 SQLserver 数据库存储的位置 想从C盘换到D盘

在 SQL Server 中更改数据库存储位置(从 C 盘迁移到 D 盘)需要通过以下步骤完成:1. 确定数据库文件的当前位置首先查询数据库文件的当前路径:sqlSELECT name, physical_name AS current_location FROM sys.master_files WHERE dat…

【unitrix】 6.8 加一运算(add_one.rs)

一、源码 这是一个使用 Rust 类型系统实现二进制数加一操作的代码。 use crate::number::{O, I, B, Null, Bit, NormalizeIf};/// 类型级加一操作 trait /// /// 为二进制数类型实现加一操作,返回新的类型 pub trait AddOne {/// 加一操作的结果类型type Output;//…

国内Ubuntu访问不了github、 huggingface等

各位小伙伴们,大家好呀。 大家是不是经常遇到访问不了github、huggingface的情况呀。 在Ubuntu中可以这样做。 访问这个网站网站测速-Ping检测-Trace查询-Dig查询-路由跟踪查询-tools.ipip.net, 对于github.com,在这个网站输入github.com…

「Java EE开发指南」如何用MyEclipse创建企业应用项目?(一)

由于有了项目模型和管理工具,现在可以创建Java EE企业应用程序。在本文中您将了解到: 企业应用项目模型项目组织、依赖关系和类解析 该特性在MyEclipse中可用。 MyEclipse v2025.1离线版下载 1. 企业应用项目模型 MyEclipse提供了一个企业应用程序项…

ubuntu 22.04 pam 模块设置用户登录失败锁定

1、ubuntu 22.04 配置方法 /etc/pam.d/common-auth 加到如下行后 # auth [success1 defaultignore] pam_unix.so nullok # 添加如下内容 auth [defaultdie] pam_faillock.so authfail auth sufficient pam_faillock.so authsucc/etc/pam.d/common…

Linux 定时任务全解析:atd 与 crond 的区别及实战案例(含日志备份 + 时间写入)

1. atd 和 crond 两个任务管理程序的区别atd:用于执行一次性的定时任务,即设置任务在某个特定的时间点仅执行一次 ,适合处理不需要重复执行的定时操作,比如在未来某个确切时间执行一个脚本、发送一份文件等场景。crond&#xff1a…

iOS加固工具有哪些?项目场景下的组合策略与实战指南

在如今的iOS项目中,“加固”不仅是单一手段,更是多工具协同应用的过程。不同项目场景对安全要求的侧重点不同,需要针对性地组合加固工具,才能最大化兼顾安全性、兼容性与效率。 本文将从常见项目场景出发,分析当下市面…

Xilinx Zynq:一款适用于软件定义无线电的现代片上系统

摘要——软件定义无线电可以在通用处理器 (CPU) 上实现,例如基于 PC 的处理器。处理器具有高度灵活性:它不仅可以用来处理数据样本,还可以控制接收器功能、显示瀑布图或运行解调软件。然而,由于处理速度相对较慢,处理器…

接口黑洞?破!安全堡垒?筑!冰火炼狱?战!MES7114W终极掌控

在工业4.0加速推进的时代,设备互联正面临三大关键挑战:多协议接口的“通信割裂”、极端环境的严苛考验,以及高危场景下的安全红线。在矿山井下、冶金车间、化工厂区等恶劣环境中,传统有线方案往往受限于高成本布线、维护困难和环境…

深入理解进程地址空间:虚拟内存与进程独立性

目录 引言 虚拟地址空间的本质 关键观察 进程地址空间布局 虚拟内存管理:mm_struct 虚拟内存的优势 总结 引言 在操作系统中,每个进程都运行在自己的独立区域中,这个区域就是​​进程地址空间​​。今天我们就来探讨这个看似真实实则虚…

Apache ActiveMQ 任意文件写入漏洞(CVE-2016-3088)复现利用

漏洞原理 Apache ActiveMQ是Apache软件基金会所研发的开放源代码消息中间件,由于ActiveMQ是一个纯Java程序,因此只需要操作系统支持Java虚拟机,ActiveMQ便可执行 本漏洞出现在fileserver应用中,漏洞原理其实非常简单&#xff0c…

谷歌地球与ArcGIS Pro查看三维地形

(1)Google Earth Web端 通过网站:https://earth.google.com/,进入谷歌地球Web端,可以查看历史影像、三维地形数据、导入kml文件等。 (2)ArcGIS Pro查看三维场景 加载3D地形数据,转…

Day06_C语言网络编程20250718

01.思维导图1 什么是 modbus他是一个在工控领域非常好用的通信写 modbus协议本质上是一个 基于 tcp 协议二次封装的一个协议 什么叫做基于tcp二次封装的协议:我们自己写的pack_t(无论静态还是动态),都是属于二次封装的协议modbus协议是一种 “主从问答式…