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 阅读 430 次 更新于 2025-09-10 09:07:49 我来答关注问题0
  • MySQL的事务如果不在任何修改,默认是自动提交的,也就是你只要执行一个SQL,回车之后这个SQL语句如果没有任何问题,只需完成后是自动提交的。控制这个功能的参数是:autocommit。如果这个参数的值是on或者1,那么就是上面我说的那种现象。如果是off或者0,则表示不会自动提交事务。需要你显示的去提交事务。

  •  深空见闻 win11怎么创建mysql数据库的命令

    或者在命令提示符(CMD)中运行net start mysql命令来启动MySQL服务。连接MySQL:打开CMD或PowerShell,输入mysql -u root -p命令,然后输入root用户的密码来登录MySQL。创建数据库:登录成功后,在MySQL命令行中输入CREATE DATABASE 数据库名;命令来创建数据库。例如,要创建一个名为learn的数据库,可以输...

  • 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...

  •  深空见闻 linux系统如何启动mysql

    使用命令行工具:可以直接使用mysqld命令来启动MySQL服务器,这通常需要root权限。命令为sudo mysqld。但请注意,这种方式较为直接,可能不如使用服务管理器来得方便和灵活。或者,如果安装了MySQL的完整包,可能会使用mysql.server脚本。命令为sudo /etc/init.d/mysql start。这种方式依赖于MySQL的安装路径...

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

mySQL相关话题

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