Django transaction.atomic()事务处理

在Django中,transaction.atomic()是一个上下文管理器,它会自动开始一个事务,并在代码块执行完毕后提交事务。如果在代码块中抛出异常,事务将被自动回滚,确保数据库的一致性和完整性。

在实际应用中,你可能需要根据具体的业务逻辑来决定何时抛出异常,以触发事务回滚。例如,如果某个操作依赖于另一个操作的成功,那么在第一个操作失败时,你可能需要抛出异常,以防止后续操作被执行,从而保持数据的一致性。

1,添加模型

Test/app11/models.py

复制代码
from django.db import models

class Post(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    pub_date = models.DateTimeField('date published')




class Book(models.Model):
    title = models.CharField(max_length=100)
    author = models.CharField(max_length=100)
    publication_date = models.DateField()
    price = models.DecimalField(max_digits=5, decimal_places=2)

    def __str__(self):
        return self.title

2,添加视图函数

Test/app11/views.py

2.1 装饰器写法

复制代码
from django.http import HttpResponse
from django.db import transaction
from .models import Post, Book
from django.utils import timezone


def atomic_transaction(func):
    def wrapper(*args, **kwargs):
        with transaction.atomic():
            try:
                return func(*args, **kwargs)
            except Exception as e:
                # 在这里可以添加错误日志记录或其他错误处理逻辑
                print(f"An error occurred: {e}")
                # 由于在transaction.atomic()上下文中,异常将自动触发事务回滚

    return wrapper


@atomic_transaction
def create_post_and_book(request):
    post_title = "New Post4"
    book_title = "New Book4"

    post = Post(title=post_title, content="This is the content of the new post.", pub_date=timezone.now())
    post.save()

    book = Book(title=book_title, author="Author Name", publication_date=timezone.now().date(), price=29.99)
    book.save()

    # 故意引发异常以测试回滚
    # if True:
    #     raise Exception("An error occurred")

    print("Post and Book created successfully.")

    return HttpResponse("Post and Book created successfully.")

2.2 with写法

复制代码
from django.http import HttpResponse
from django.db import transaction
from .models import Post, Book
from django.utils import timezone


def create_post_and_book(request):
    post_title = "New Post3"
    book_title = "New Book3"

    with transaction.atomic():
        post = Post(title=post_title, content="This is the content of the new post.", pub_date=timezone.now())
        post.save()

        # 故意引发异常以测试回滚
        if True:
            raise Exception("An error occurred")

        book = Book(title=book_title, author="Author Name", publication_date=timezone.now().date(), price=29.99)
        book.save()

    return HttpResponse("Post and Book created successfully.")

3,添加路由应用

Test/app11/urls.py

复制代码
from django.urls import path
from . import views

urlpatterns = [

    path('create_post_and_book/', views.create_post_and_book, name='create_post_and_book'),
]

4,访问页面

http://127.0.0.1:8000/app11/create_post_and_book/

当你的代码中抛出异常,如raise Exception("An error occurred"),这会中断程序的正常执行流程。在Django的事务处理中,如果在transaction.atomic()的上下文中抛出异常,Django会捕获这个异常并自动回滚事务,确保任何在事务开始后所做的数据库更改不会被永久保存。

可以看到数据并没有被保存到

在这个例子中,由于if True:条件总是为真,因此raise Exception("An error occurred")这一行代码将总是抛出异常。结果,transaction.atomic()会捕获这个异常并回滚事务,这意味着Post和Book对象都不会被保存到数据库中,因为事务没有成功提交。这是Django事务处理的一个关键特性,它确保了数据的一致性和完整性,避免了部分完成的事务可能导致的数据库状态不一致问题。

相关推荐
AI_56782 小时前
Selenium+Python可通过 元素定位→操作模拟→断言验证 三步实现Web自动化测试
服务器·人工智能·python
蒜香拿铁2 小时前
【第三章】python算数运算符
python
浮尘笔记3 小时前
Go语言临时对象池:sync.Pool的原理与使用
开发语言·后端·golang
52Hz1184 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
梦梦代码精4 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
weixin_462446235 小时前
Python 使用 openpyxl 从 URL 读取 Excel 并获取 Sheet 及单元格样式信息
python·excel·openpyxl
REDcker5 小时前
RESTful API设计规范详解
服务器·后端·接口·api·restful·博客·后端开发
毕设源码-钟学长5 小时前
【开题答辩全过程】以 基于Python的健康食谱规划系统的设计与实现为例,包含答辩的问题和答案
开发语言·python
百***78756 小时前
Grok-4.1技术深度解析:双版本架构突破与Python API快速集成指南
大数据·python·架构
2501_942191777 小时前
基于YOLO11-HSFPN的数字检测与识别模型实现详解
python