当前位置: 首页 > wzjs >正文

如何做https网站河源今日头条新闻最新

如何做https网站,河源今日头条新闻最新,怎么做黑彩黑彩网站,政府网站建设绩效评估指标跟韩学AiOps系列之2025学MySQL系列_如何在MySQL中开启和提交事务?! 文章目录 一、事务的基本操作1. 开启事务2. 执行事务内操作3. 提交事务4. 回滚事务 二、验证示例(适用于 MySQL 5.7)步骤 1:准备测试表和数据步骤 2&#xff1a…

跟韩学AiOps系列之2025学MySQL系列_如何在MySQL中开启和提交事务?!

文章目录

      • 一、事务的基本操作
        • 1. 开启事务
        • 2. 执行事务内操作
        • 3. 提交事务
        • 4. 回滚事务
      • 二、验证示例(适用于 MySQL 5.7)
        • 步骤 1:准备测试表和数据
        • 步骤 2:执行转账事务
        • 验证结果
      • 三、自动提交模式
        • 1. 查看当前自动提交状态
        • 2. 关闭自动提交
        • 3. 重新开启自动提交
      • 四、完整示例(含回滚)
      • 五、关键注意事项
      • 六、事务的典型应用场景

在 MySQL 中,事务的开启和提交是保证数据一致性的核心操作。以下是清晰的操作步骤和示例:


一、事务的基本操作

1. 开启事务

有两种方式显式开启事务:

  • 方式 1:使用 START TRANSACTION
    START TRANSACTION; -- 开始事务
    
  • 方式 2:使用 BEGIN
    BEGIN; -- 与 START TRANSACTION 等效
    
2. 执行事务内操作

在事务内可以执行任意 SQL 操作(DML语句):

UPDATE accounts SET balance = balance - 100 WHERE user_id = 1; -- 扣款
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2; -- 收款
SELECT * FROM accounts; -- 查询数据状态(此时数据尚未持久化)
3. 提交事务

将事务内的所有操作永久生效:

COMMIT; -- 提交事务,数据写入磁盘
4. 回滚事务

取消事务内的所有操作:

ROLLBACK; -- 回滚事务,撤销未提交的修改

二、验证示例(适用于 MySQL 5.7)

步骤 1:准备测试表和数据
-- 创建测试表
CREATE TABLE accounts (user_id INT PRIMARY KEY,balance DECIMAL(10,2)
) ENGINE=InnoDB; -- 必须使用 InnoDB 引擎-- 插入测试数据
INSERT INTO accounts (user_id, balance) VALUES
(1, 500.00),
(2, 0.00);
步骤 2:执行转账事务
-- 开启事务
START TRANSACTION;-- 从用户1扣款100元
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;-- 向用户2收款100元
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;-- 提交事务(只有提交后数据才持久化)
COMMIT;
验证结果
SELECT * FROM accounts;
-- 结果:
-- user_id=1, balance=400.00
-- user_id=2, balance=100.00

三、自动提交模式

MySQL 默认启用自动提交(每条 SQL 单独作为一个事务):

1. 查看当前自动提交状态
SELECT @@autocommit; -- 返回 1 表示启用,0 表示禁用
2. 关闭自动提交
SET autocommit = 0; -- 关闭自动提交

此时需手动执行 COMMITROLLBACK

3. 重新开启自动提交
SET autocommit = 1; -- 重新启用自动提交

四、完整示例(含回滚)

-- 关闭自动提交
SET autocommit = 0;-- 开启事务(可选,BEGIN 也可)
START TRANSACTION;-- 用户1尝试扣款200元
UPDATE accounts SET balance = balance - 200 WHERE user_id = 1;-- 发现余额不足(假设余额不能为负),主动回滚
ROLLBACK; -- 所有修改撤销-- 重新开启自动提交
SET autocommit = 1;

五、关键注意事项

  1. 存储引擎:只有 InnoDB 支持事务(MyISAM 不支持)。
  2. 隔离级别:事务的可见性由隔离级别控制(默认 REPEATABLE READ)。
  3. 锁机制:事务中的操作可能隐式或显式加锁(如 SELECT ... FOR UPDATE)。
  4. 长事务风险:避免未及时提交的事务长时间持有锁,导致性能问题。

六、事务的典型应用场景

  • 转账操作:扣款和收款需原子性保证。
  • 订单创建:创建订单与扣减库存要一致。
  • 批量数据处理:确保批量操作的完整性。

通过合理使用事务,可以确保复杂操作的数据一致性!

http://www.dtcms.com/wzjs/19311.html

相关文章:

  • 网站开发工程师考试产品宣传推广方案
  • 完善网站建设的方法店铺推广方式有哪些
  • 如何做网站软件公司网页设计模板
  • 链接网站logo产品seo基础优化
  • 专业APP客户端做网站如何搭建一个网站
  • 哪些公司网站做的好百度移动
  • 网络营销策划步骤有哪些网络优化工作内容
  • 浙江公司网站建设制作网站建设建站在线建站
  • css网站模板下载外链互换平台
  • 郑州网站设计与制作国际网络销售平台有哪些
  • 服务好的高端网站建设服务商优化设计三年级上册语文答案
  • 做网站过时了seo外包公司需要什么
  • wordpress 会员 下载广州网站优化工具
  • 网站建设需要的人员社群营销的方法和技巧
  • 做网站大深圳网站seo推广
  • 惠州市 网站开发公司软文写作要求
  • 自己做游戏网站学什么制作企业网站
  • wordpress邮箱验证配置杭州seo建站
  • 网站建设文化咨询福州seo经理招聘
  • app开发教程视频落实好疫情防控优化措施
  • 免费素材网站可商用常见的营销策略有哪些
  • 怎样在网站图片上做店铺广告关键词指数查询工具
  • 政务网站设计新闻媒体发稿平台
  • 找人做网站服务器不是自己的怎么办手机搜索引擎排行榜
  • 广州做鞋的网站编程培训班学费一般多少钱
  • 机械加工网络接单seo优化基础教程pdf
  • ps做网站对齐技巧网络推广专员
  • 网站做的支付宝接口企业网络推广的方式有哪些
  • 长春做网站seo企业seo培训
  • 网络营销方式的特点seo排名软件哪个好用