• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL中关于事务的具体详解

MySQL中关于事务的具体详解

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,详解,具体等相关知识,希望本文的分享对您有所帮助

MySQL事务:

1.MySQL事务控制语句

(1).开启事务

begin;

(2).提交事务

commit;

(3).回滚事务

rollback;

(4).设置事务是否自动提交

set autocommit = {0 | 1}; // 0不自动提交,1自动提交

例如:

begin;// 开启事务
insert into table_name values(内容);
commit;// 提交事务

这个就是一个简单的插入数据的事务

begin;// 开启事务
insert into table_name values(内容);// 后悔了,不想插入数据了
rollback;// 回滚,取消这次的事务操作

这个就是一个简单的插入数据的回滚事务

2.MySQL事务隔离语句

查看MySQL的隔离级别

show variables like 'tx_isolation';

(1).read-uncommitted(读取未提交内容)

脏读(带来的问题);

一个用户在两次查询结果中的内容不相同.

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level read uncommitted;

两个用户同时登录数据库,分别开启事务,一个用户的事务执行增删改操作,另一个用户的事务只进行查询操作,前者执行完操作,不进行提交,后者就可以看到操作结果,但如果这时候前者进行了事务的回滚,后者这时候查询就会看到不一样与上次不一样的结果(也就是没有进行操作的结果),这就是脏读问题.

(2).read committed(读取提交内容)

事务只能看见已经提交事务所做的改变,同一查询可能返回不同的结果,此级别导致的不可重复读问题.

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level read committed;

在一次事务中,看到了两次不一样的查询结果(与脏读类似).

(3).repeatable read(可重复读)

能确保同一事务的多个实例在并发读取数据时,会看到同样的数据行(数据库的莫尔纳隔离级别).

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level repeatable read;

也就在在一次事务中,无论另一个用户如何修改数据,在这次事务中查询到的结果总是相同.

***隐式事务提交***:

alter table users engine = innodb;// 会造成事务的隐式提交

3.InnoDB锁机制

(1).一个表中没有任何的主键和索引,一个事务会锁住这个表的所有记录,其他的事务无法进行操作这个表.

(2).一个表中存在主键或者索引,一个事务会锁住表的他操作的某行数据,不回锁住整个表,如果其他的事务操作这个表的其他数据,这个时候是不受影响的.需要注意的是这的行级锁是间隙锁,也就是说如果你修改的某几行数据,比如过修改id<10的n行数据.=,这时,id = 11的数据也会被锁住,这是需要注意的.

以上就是MySQL中关于事务的具体详解的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05关于mysql_error()函数的10篇文章推荐
  • 2018-12-05mysql用户常见操作
  • 2018-12-05Oracle寄售功能 价格客制化
  • 2018-12-05MySQl在开发和生产不同环境下的索引对比
  • 2018-12-05使用 GUID 值来作为数据库行标识讲解
  • 2018-12-05MySQL 随机查询数据与随机更新数据实现代码
  • 2018-12-05MySQL存储引擎初探
  • 2018-12-05MongoDB结合Flexgrid的简单数据呈现
  • 2018-12-05mysql数据库基础语句训练题详细代码
  • 2018-12-05MySQL数据库如何解决无法被其他ip访问的方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql 增加和删除用户的访问权限和删除
    • SQL Server 2005“备份集中的数据库备份与现有的数据库不同”解
    • MySQL入门教程3 —— 创建、选择并使用数据库
    • MYSQL的随机查询的实现方法
    • mysql Myisamchk小工具使用手册第1/2页
    • 在SQL Server Management Studio中可以运行作业但是用T-SQL运行
    • MySQL存储过程例子(包含事务,输出参数,嵌套调用)
    • 解析mysql 5.5字符集问题
    • MySQL连接无法解析HOST主机名的解决方法
    • 如何设置才能远程登录Mysql数据库

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有