MYSQL事务的开启与提交,MYSQL事务的开启与提交

MYSQL 事务处理主要有两种方法:

1、用 BEGIN, ROLLBACK, COMMIT来实现

BEGIN 开始一个事务

ROLLBACK 事务回滚

COMMIT 事务确认

2、直接用 SET 来改变 MySQL 的自动提交模式:

SET AUTOCOMMIT=0 禁止自动提交

SET AUTOCOMMIT=1 开启自动提交

对于一个MYSQL数据库(InnoDB),事务的开启与提交模式无非下面这两种情况:

1>若参数autocommit=0,事务则在用户本次对数据进行操作时自动开启,在用户执行commit命令时提交,用户本次对数据库开始进行操作到用户执行commit命令之间的一系列操作为一个完整的事务周期。若不执行commit命令,系统则默认事务回滚。总而言之,当前情况下事务的状态是自动开启手动提交。

2>若参数autocommit=1(系统默认值),事务的开启与提交又分为两种状态:

①手动开启手动提交:当用户执行start transaction命令时(事务初始化),一个事务开启,当用户执行commit命令时当前事务提交。从用户执行start transaction命令到用户执行commit命令之间的一系列操作为一个完整的事务周期。若不执行commit命令,系统则默认事务回滚。

②自动开启自动提交:如果用户在当前情况下(参数autocommit=1)未执行start transaction命令而对数据库进行了操作,系统则默认用户对数据库的每一个操作为一个孤立的事务,也就是说用户每进行一次操作系都会即时提交或者即时回滚。这种情况下用户的每一个操作都是一个完整的事务周期。

$dbhost= ‘localhost:3306‘; //mysql服务器主机地址

$dbuser = ‘root‘; //mysql用户名

$dbpass = ‘123456‘; //mysql用户名密码

$conn =mysqli_connect($dbhost, $dbuser, $dbpass);if(!$conn )

{

die(‘连接失败:‘. mysqli_error($conn));

}//设置编码,防止中文乱码

mysqli_query($conn, "set names utf8");

mysqli_select_db( $conn,‘RUNOOB‘);

mysqli_query($conn,"SET AUTOCOMMIT=0"); //设置为不自动提交,因为MYSQL默认立即执行

mysqli_begin_transaction($conn); //开始事务定义

if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(8)"))

{

mysqli_query($conn,"ROLLBACK"); //判断当执行失败时回滚

}if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(9)"))

{

mysqli_query($conn,"ROLLBACK"); //判断执行失败时回滚

}

mysqli_commit($conn);//执行事务

mysqli_close($conn);?>

Django的事务开启两种方式

#第一种 导入模块fromdjango.db import transaction

with transaction.atomic():

...

#第二种 装饰器

@transaction.atomic

def post(self,request):

...

sid=transaction.savepoint() #开启事务

...

transaction.savepoint_rollback(sid) # 回滚

...

transaction.savepoint_commit(sid) # 提交

原文:https://www.cnblogs.com/jiangxiaobo/p/11648943.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值