草庐IT

nested-transactions

全部标签

python - 在 django 中引发异常的 transaction.rollback() 的正确方法

我正在使用Django1.7.1和python2.7,我正在做一些需要在事务内的POST请求,实际上我正在使用@transaction.atomic()装饰器,它使整个函数都在事务中。据我所知,这个装饰器类似于commit_on_success并在出现数据库错误时进行回滚。是否可以引发自定义异常,使事务回滚但不使用保存点?我想在回滚完成时返回一个HttpResponse,解释事务未完成的原因。我有这个。@transaction.atomic()defsalida_de_almacen(request):ifrequest.method=='POST':try:folio=request

python - GAE/P : Transaction safety with API calls

假设您使用交易来处理Stripe付款并更新用户实体:@ndb.transactionaldefprocess_payment(user_key,amount):user=user_key.get()user.stripe_payment(amount)#APIcalltoStripeuser.balance+=amountuser.put()有可能StripeAPI调用成功但put由于争用而失败。然后将向用户收费,但他的帐户不会反射(reflect)付款。您可以将StripeAPI调用从交易中拉出,然后再进行交易,但您似乎仍然遇到同样的问题。扣款成功但交易失败,用户账户未入账。这似乎是

python - Django Rest Framework 3.0 : Saving Nested, 多对一关系

我正在尝试使用DjangoRestFramework3.0构建嵌套关系。我已经创建了序列化器并试图覆盖create()函数。我的模型定义如下:classItem(models.Model):user=models.ForeignKey(settings.AUTH_USER_MODEL)name=models.CharField(max_length=200)description=models.CharField(max_length=1000)categories=models.ManyToManyField(Category,null=True,blank=True)classPr

python - 将 transaction.commit_manually() 升级到 Django > 1.6

我继承了为Django1.4编写的应用程序的一些代码。我们需要更新代码库以使用Django1.7,并最终将1.8作为下一个长期支持版本。在一些地方它使用旧样式@transaction.commit_manually和withtransaction.commit_manually:我对事务的一般了解还不够,但我想了解它们的用途,所以我可以删除它们(如果不需要)或将它们升级到较新的set_autocommit(False)或等价物。我了解到Django数据库连接看起来是这样的,没有特殊的事务管理。(使用Postgres9.3)DATABASES={'default':{'ENGINE':'

python - 我应该如何在 Python 中实现 "nested"子命令?

使用cmdln在Python中实现“嵌套”子命令。我不确定我在这里使用的术语是否正确。我正在尝试使用cmdln实现命令行工具允许“嵌套”子命令。这是一个真实世界的例子:gitsvnrebase实现它的最佳方法是什么?我一直在文档、此处和整个网络中搜索有关此的更多信息,但都没有找到。(也许我搜索的词有误。)缺少自动执行此操作的未记录功能,我最初的想法是让先前的子命令处理程序确定存在另一个子命令并再次分派(dispatch)命令调度程序。不过,我查看了cmdln的内部结构,调度程序是一个私有(private)方法_dispatch_cmd。我的下一个想法是创建我自己的sub-sub-com

python - django 信号是否也包含在 transaction.atomic 装饰器中?

我有一个模型文件,它使用post_save信号在另一个表中创建链接行。以典型的方式,我可以从我的一个View创建一个页面,该页面用@transaction.atomic装饰。我想知道这个装饰器是否会将Page对象的创建和SharedPage对象的创建放在同一个事务中。从django文档中不清楚信号是该原子事务的一部分。模型.pyclassPage(models.Model):name=models.CharField(default='Mydefaultpage',max_length=200,blank=False)created_at=models.DateTimeField(au

python - Django transaction.atomic() 保证原子读+写?

我需要确保从数据库读取并写回的对象不能同时被另一个请求/进程修改。transaction.atomic()能保证吗?到目前为止,我的测试告诉我没有。如果它们没有任何问题,那么实现原子读取和写入的正确方法是什么?我测试过的示例。将Test类放在模型中的某处。atomic_test.py和atomic_test2.py应该保存为管理命令。先运行pythonmanage.pyatomic_test,然后运行​​pythonmanage.pyatomic_test2。第二个脚本不会阻塞,它的更改会丢失。模型.pyclassTest(models.Model):value=models.Inte

nested exception is java.sql.SQLException: connection disabled

标题:解决SpringBoot连接数据库出现"connectiondisabled"异常在使用SpringBoot连接数据库时,有时候会遇到"nestedexceptionisjava.sql.SQLException:connectiondisabled"异常。这个异常通常是由以下原因引起的:数据库连接配置错误:检查数据库连接的URL、用户名和密码是否正确配置。确保URL中包含正确的数据库名称,并且用户名和密码与数据库中的凭据匹配。数据库服务未启动:如果数据库服务未启动,或者端口被占用,那么连接将失败。确保数据库服务正在运行,并且在连接之前检查相关的端口是否可用。数据库连接池问题:如果使用连

解决“Failed to start bean ‘documentationPluginsBootstrapper‘; nested exception is java.lang.NullPoint”

当你的spring-boot版本是2.6.x并且你的swagger版本是3.0.0以上的时候,项目启动会报错“org.springframework.context.ApplicationContextException:Failedtostartbean'documentationPluginsBootstrapper';nestedexceptionisjava.lang.NullPointerException”解决办法步骤一、添加配置spring:mvc:pathmatch:matching-strategy:ant_path_matcher步骤二、添加配置类importorg.spr

Android Binder机制浅谈以及使用Binder进行跨进程通信的俩种方式(AIDL以及直接利用Binder的transact方法实现)

Binder机制学习Binder机制是Android进行IPC(进程间通信)的主要方式Binder跨进程通信机制:基于C/S架构,由Client、Server、ServerManager和Binder驱动组成。进程空间分为用户空间和内核空间。用户空间不可以进行数据交互;内核空间可以进行数据交互,所有进程共用一个内核空间Client、Server、ServiceManager均在用户空间中实现,而Binder驱动程序则是在内核空间中实现的;·为何新增Binder来作为主要的IPC方式Android也是基于Linux内核,Linux现有的进程通信手段有管道/消息队列/共享内存/套接字/信号量。既然