在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
基础知识 事务是指对一组 SQL 语句进行一个原子化的操作,即如果这一组 SQL 语句中有一条发生错误,那么其他的同组 SQL 就都不会被执行。 你可以把它当作一个测试,当你执行完一组 SQL 语句后,可以查看一下结果是否正确,如果正确后可以选择提交,如果不正确则可以进行回滚,恢复到原本的状态。 在 MySQL 中,所有的操作默认都是自动进行提交,当开启事务后则变为手动提交。 基本使用 单独开启 单独开启是指对某一组的 SQL 语句开启事务。 CREATE TABLE user( id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY, name CHAR(12) NOT NULL, balance INT UNSIGNED ); -- 创建用户表 INSERT INTO user(name,balance) VALUES ("Yunya",1000), ("Ken",500); -- 插入数据 start transaction; -- 开启事务,增删改操作均要手动提交 UPDATE user SET balance = 500 WHERE name = "Yunya"; -- Yunya对Ken转账500 UPDATE user SET balance = 1000 WHERE name = "Ken"; SELECT * FROM user; -- 验证是否出错 COMMIT; -- 提交事务:手动提交上面两条UPDATE -- ROLLBACK; -- 事务回滚:转账金额不对时使用回滚 BEGIN -- 关闭事务,增删改操作均自动提交 全局开启 如果所有 SQL 都使用事务操作,我们可以通过 SET AUTOCOMMIT=0 关闭自动提交来开启事务机制,这样所有语句都是事务类型。 -- 关闭自动提交 SET AUTOCOMMIT = 0; INSERT INTO user(name,balance) VALUES ('Jack',8000); COMMIT; -- 开启自动提交 SET AUTOCOMMIT = 1; 事务隔离 并发问题 当高并发访问会遇到多个事务的隔离问题,可能会出现以下: 脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据 隔离级别 系统默认隔离级别为3级,可能出现幻读的情况。
查询设置 查询隔离级别 select @@tx_isolation; 设置隔离级别 set session transaction isolation level read uncommitted; -- set session只对当前会话有效,set global则对全局有效 以上就是MySQL 如何使用事务的详细内容,更多关于MySQL 事务的资料请关注极客世界其它相关文章! |
请发表评论