mysql命令行什么时候需要手动开启事务?

MySQL的事务如果不在任何修改,默认是自动提交的,也就是你只要执行一个SQL,回车之后这个SQL语句如果没有任何问题,只需完成后是自动提交的。控制这个功能的参数是:autocommit。如果这个参数的值是on或者1,那么就是上面我说的那种现象。如果是off或者0,则表示不会自动提交事务。需要你显示的去提交事务...
mysql命令行什么时候需要手动开启事务?
MySQL的事务如果不在任何修改,默认是自动提交的,也就是你只要执行一个SQL,回车之后这个SQL语句如果没有任何问题,只需完成后是自动提交的。
控制这个功能的参数是:autocommit。如果这个参数的值是on或者1,那么就是上面我说的那种现象。如果是off或者0,则表示不会自动提交事务。需要你显示的去提交事务。否则锁执行的SQL不会不会永久生效,只会对你当前命令行的session有效,退出MySQL后,执行的SQL语句将会别回滚。
当你需要两个SQL语句同时成功或者同时失败的时候,你可以手动地开启一个事务。比如下面的场景:
你想向订单表order_info表中插入一条新的订单记录,同时要想支付信息表payment_info中插入一条支付信息记录,这个时候从业务的角度上来看,这两个表中的插入操作,需要保持原子性(也就是事务的四大特性之一),也就是要么都插入成功,要么都插入失败,不能存在订单插入成功,支付插入失败,反之也不可以。
要满足上面的需求,你就需要手动的去开启一个事务,在这个事务中去插入两个表中的数据。然后再提交这个事务。如果这两个表的插入操作,你不手动的开启事务,MySQL自己会把两个SQL语句分开放在两个单独的事务中。执行一个插入,就会自动提交一个事务,然后在执行另外一个插入,再自动提交另外一个事务。
在MySQL看来,这是两个分别向两个表中插入的SQL语句而已,它不会从业务上考虑这两个SQL实际的业务逻辑背景是什么。所以此时他会看成是两个SQL语句,也就是两个事务。
这样的情况下就需要手动的开启事务。2020-10-27
mengvlog 阅读 528 次 更新于 2025-10-31 06:30:06 我来答关注问题0
  • MySQL的事务如果不在任何修改,默认是自动提交的,也就是你只要执行一个SQL,回车之后这个SQL语句如果没有任何问题,只需完成后是自动提交的。控制这个功能的参数是:autocommit。如果这个参数的值是on或者1,那么就是上面我说的那种现象。如果是off或者0,则表示不会自动提交事务。需要你显示的去提交事务。

  • 打开系统的环境变量设置界面,找到path这一环境变量项,然后点击编辑按钮。在弹出的窗口中,点击新建按钮,输入MySQL的bin路径。如果MySQL的安装目录是C:\Program Files\MySQL\MySQL Server 8.0\bin,那么应该添加这个路径。点击确定保存更改。完成上述步骤后,重新打开CMD命令行窗口。输入命令“mysql -u 用...

  • mysql -uroot -p123456 -e “create database testdb; use testdb; create table testtable (id int primary key auto_increment, name varchar(20) not null);”保存后,在CMD下执行test.bat命令,即可完成批处理操作。2.将CMD命令输出到文件 有时候我们需要将CMD操作的结果输出到文...

  • 1.打开cmd命令行工具 2.进入mysql目录下的bin目录(也就是C:\mysql-5.7.31-winx64\bin)3.使用mysqld –install命令来创建MySQL服务 示例:C:\mysql-5.7.31-winx64\bin>mysqld –install MySQL57 –defaults-file=C:\mysql-5.7.31-winx64\my.ini 解释:–install...

  • MySQL SQL 命令行界面是MySQL数据库管理系统上的一种接口,可以通过它执行与数据库管理和应用程序开发有关的复杂SQL查询。本文将详细描述如何打开MySQL SQL命令行界面,使您能够轻松上手MySQL的强大功能,同时阐述SQL的基础知识。首先需要准备的工具有:MySQL数据库服务器安装和配置,一台电脑,使用MySQL数据...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部