首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql开启事务sql语句

基础概念

MySQL中的事务(Transaction)是一组一起执行或都不执行的SQL语句。事务的主要目的是确保数据库操作的一致性和完整性。如果事务中的某个操作失败,整个事务可以回滚(Rollback),撤销所有已完成的操作,从而保持数据库的一致性。

相关优势

  1. 原子性(Atomicity):事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
  2. 一致性(Consistency):事务必须使数据库从一个一致性状态变换到另一个一致性状态。
  3. 隔离性(Isolation):事务的执行不能被其他事务干扰,即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不会互相干扰。
  4. 持久性(Durability):一旦事务提交,则其结果就是永久的,即使系统崩溃也不会丢失。

类型

MySQL支持两种事务隔离级别:

  1. 读未提交(Read Uncommitted)
  2. 读已提交(Read Committed)
  3. 可重复读(Repeatable Read)(MySQL默认隔离级别)
  4. 串行化(Serializable)

应用场景

事务广泛应用于需要确保数据一致性和完整性的场景,例如:

  • 银行转账
  • 订单处理
  • 用户注册和登录

开启事务的SQL语句

在MySQL中,可以使用以下语句开启事务:

代码语言:txt
复制
START TRANSACTION;

或者使用BEGIN关键字:

代码语言:txt
复制
BEGIN;

示例代码

假设有一个银行转账的场景,用户A向用户B转账100元:

代码语言:txt
复制
START TRANSACTION;

-- 减少用户A的余额
UPDATE accounts SET balance = balance - 100 WHERE user_id = 'A';

-- 增加用户B的余额
UPDATE accounts SET balance = balance + 100 WHERE user_id = 'B';

-- 提交事务
COMMIT;

如果在上述操作中任何一个步骤失败,可以使用ROLLBACK回滚事务:

代码语言:txt
复制
START TRANSACTION;

-- 减少用户A的余额
UPDATE accounts SET balance = balance - 100 WHERE user_id = 'A';

-- 增加用户B的余额
UPDATE accounts SET balance = balance + 100 WHERE user_id = 'B';

-- 假设某个操作失败
-- 回滚事务
ROLLBACK;

参考链接

通过以上信息,您可以了解MySQL事务的基础概念、优势、类型、应用场景以及如何开启和使用事务。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • MySQL常用SQL语句大全

    ,    //设置默认列值     >PRIMARY KEY(id)     >)ENGINE=InnoDB    //设置表的存储引擎,一般常用InnoDB和MyISAM;InnoDB可靠,支持事务...BETWEEN a AND b、NOT     AND 、OR     Linke()用法中 % 为匹配任意、 _ 匹配一个字符(可以是汉字)     IS NULL 空值检测 八、MySQL...的正则表达式:   1、Mysql支持REGEXP的正则表达式:     >SELECT * FROM tb_name WHERE name REGEXP ‘^[A-D]’ //找出以A-D 为开头的...九、MySQL的一些函数:   1、字符串链接——CONCAT()     >SELECT CONCAT(name,’=>’,score) FROM tb_name   2、数学函数:     ...FROM tb_name [ WHERE …… ] ;    11、ROLLBACK(撤销一个事务处理块)     ROLLBACK [ TO savapointname ];    12、

    2.5K20

    MySQL指南之SQL语句基础

    ---- 零、结构化查询语言:SQL(Structured Query Language) DDL 数据定义语言 管理库,表 DML 数据操作语言 增删改查 DCL 数据控制语言...来一波字符串操作 MySQL查询LEVER2.png 1.建表语句 CREATE TABLE pic( id INT UNSIGNED AUTO_INCREMENT PRIMARY...| +----------------------+--------+ ---- 三、子查询 (LEVER 3) 1.查询大于平均尺寸的图片 -- WHERE |--- 出现在其他SQL...语句内的SELECT语句 |--- 子查询必须在()内 |--- 增删改查都可以进行子查询,返回:标量,行,列或子查询 |-- 1-1:查出图片平均大小 SELECT ROUND(AVG(pic_length...全(外)连接 (伪):使用UNION MySQL不支持全外连接,所以只能采取关键字UNION来联合左、右连接的方法 UNION : 将若干条sql的查询结果集合并成一个。

    4.5K30
    领券