MySQL 提供了多种事务型存储引擎,如 InnoDB 和 BDB 等,而 MyISAM 不支持事务。为了支持事务,InnoDB 存储引擎引入了与事务处理相关的 REDO 日志和 UNDO 日志,同时事务依赖于 MySQL 提供的锁机制
事务执行时需要将执行的事务日志写入日志文件,对应的文件为 REDO 日志。当每条 SQL 进行数据更新 *** 作时,首先将 REDO 日志写进日志缓冲区。当客户端执行 COMMIT 命令提交时,日志缓冲区的内容将被刷新到磁盘,日志缓冲区的刷新方式或者时间间隔可以通过参数 innodb_flush_log_at_trx_commit 控制
REDO 日志对应磁盘上的 ib_logifleN 文件,该文件默认为 5MB,建议设置为 512MB,以便容纳较大的事务。MySQL 崩溃恢复时会重新执行 REDO 日志的记录,恢复最新数据,保证已提交事务的持久性
与 REDO 日志相反,UNDO 日志主要用于事务异常时的数据回滚,具体内容就是记录数据被修改前的信息到 UNDO 缓冲区,然后在合适的时间将内容刷新到磁盘
假如由于系统错误或者 rollback *** 作而导致事务回滚,可以根据 undo 日志回滚到没修改前的状态,保证未提交事务的原子性
与 REDO 日志不同的是,磁盘上不存在单独的 UNDO 日志文件,所有的 UNDO 日志均存在表空间对应的 .ibd 数据文件中,即使 MySQL 服务启动了独立表空间
在 MySQL 中,可以使用 BEGIN 开始事务,使用 COMMIT 结束事务,中间可以使用 ROLLBACK 回滚事务。MySQL 通过 SET AUTOCOMMIT、START TRANSACTION、COMMIT 和 ROLLBACK 等语句支持本地事务
MySQL 定义了四种隔离级别,指定事务中哪些数据改变其他事务可见、哪些数据该表其他事务不可见。低级别的隔离级别可以支持更高的并发处理,同时占用的系统资源更少
InnoDB 系统级事务隔离级别可以使用以下语句设置:
查看系统级事务隔离级别:
InnoDB 会话级事务隔离级别可以使用以下语句设置:
查看会话级事务隔离级别:
在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。读取未提交的数据称为脏读(Dirty Read),即是:首先开启 A 和 B 两个事务,在 B 事务更新但未提交之前,A 事务读取到了更新后的数据,但由于 B 事务回滚,导致 A 事务出现了脏读现象
所有事务只能看见已经提交事务所做的改变,此级别可以解决脏读,但也会导致不可重复读(Nonrepeatable Read):首先开启 A 和 B 两个事务,A事务读取了 B 事务的数据,在 B 事务更新并提交后,A 事务又读取到了更新后的数据,此时就出现了同一 A 事务中的查询出现了不同的查询结果
MySQL 默认的事务隔离级别,能确保同一事务的多个实例在并发读取数据时看到同样的数据行,理论上会导致一个问题,幻读(Phontom Read)。例如,第一个事务对一个表中的数据做了修改,这种修改会涉及表中的全部数据行,同时第二个事务也修改这个表中的数据,这次的修改是向表中插入一行新数据,此时就会发生 *** 作第一个事务的用户发现表中还有没有修改的数据行
InnoDB 通过多版本并发控制机制(MVCC)解决了该问题:InnoDB 通过为每个数据行增加两个隐含值的方式来实现,这两个隐含值记录了行的创建时间、过期时间以及每一行存储时间发生时的系统版本号,每个查询根据事务的版本号来查询结果
通过强制事务排序,使其不可能相互冲突,从而解决幻读问题。简而言之,就是在每个读的数据行上加上共享锁实现,这个级别会导致大量的超时现象和锁竞争,一般不推荐使用
为了解决数据库并发控制问题,如走到同一时刻客户端对同一张表做更新或者查询 *** 作,需要对并发 *** 作进行控制,因此产生了锁
共享锁的粒度是行或者元组(多个行),一个事务获取了共享锁以后,可以对锁定范围内的数据执行读 *** 作
排他锁的粒度与共享锁相同,一个事务获取排他锁以后,可以对锁定范围内的数据执行写 *** 作
有两个事务 A 和 B,如果事务 A 获取了一个元组的共享锁,事务 B 还可以立即获取这个元组的共享锁,但不能获取这个元组的排他锁,必须等到事务 A 释放共享锁之后。如果事务 A 获取了一个元组的排他锁,事务 B 不能立即获取这个元组的共享锁,也不能立即获取这个元组的排他锁,必须等到 A 释放排他锁之后
意向锁是一种表锁,锁定的粒度是整张表,分为意向共享锁和意向排他锁。意向共享锁表示一个事务有意对数据上共享锁或者排他锁。有意表示事务想执行 *** 作但还没真正执行
锁的粒度主要分为表锁和行锁
表锁的开销最小,同时允许的并发量也是最小。MyISAM 存储引擎使用该锁机制。当要写入数据时,整个表记录被锁,此时其他读/写动作一律等待。一些特定的动作,如 ALTER TABLE 执行时使用的也是表锁
行锁可以支持最大的并发,InnoDB 存储引擎使用该锁机制。如果要支持并发读/写,建议采用 InnoDB 存储引擎
数据库系统中,关系是指由多个记录组成的集合,每个记录由一组相关的属性值组成。关系可以被视为一张表格,其中的每一行表示一个记录,每一列表示一个属性。
数学上,关系可以被表示为一个二元组 (R, A),其中 R 是一个有限集合,A 是 R 中每个元素的属性集合。
例如,对于一个学生关系,R 可能是所有学生的集合,而 A 可能包括学生的姓名、年龄、学号等属性。
因此,关系可以被表示为一个由记录组成的集合,每个记录由一组相关的属性值组成。
mysql 数据库join,怎么定义字段别名推荐内容
mysql 数据库join,怎么定义字段别名
来自匿名用户的提问
回答
最佳答案
select columnname as col1 from tablename t1
直接在后面写别名就可以了啊
2017-04-07
抢首赞
更多回答(1)
数据库mysql培训_传智教育_致力于培养高级软件工程师
口碑品牌
来传智数据库mysql培训,java课程培训,结合企业时代发展,不断加入新/热技术点.数据库mysql培训,项目实战教学,层层递进,课程设置贴合企业用人需求,多种职业规划...
Java培训
视频教程
基础入门
学习路线
m.itcast.cn
广告
mysql数据库学习_HTML&JS+前端培训_前端学习路线图
口碑品牌
黑马程序员HTML&JS+前端培训,项目实战教学,模拟企业真实开发,引入三大流行框架,mysql数据库学习,实及时更新热门技术,课程体系契合企业需求,学习即积累项目经验.
javaEE培训
Python大数据开发
人工智能
软件测试
HTML&JS+前端
产品经理
UI/UE设计
新媒体运营
机器人培训
itheima.itcast.cn
广告
xampp mysql怎么连接数据库_优质推荐
查询xampp mysql怎么连接数据库,我们为您推荐更多优质商家,资质保证,放心选择有保障!
商家列表
广告
相关搜索
mysql给表添加字段mysql拼接字段的函数mysql截取字段前几位mysql设置字段默认值mysql增加字段的语句mysql给表新增字段mysql删除一个字段mysql给表增加字段
mysql数据库 字段类型
赞0答1
mysql数据库表字段多少合适
赞0答2
MySQL数据库,如何给数据库表和表字段添加备注?
赞0答4
mysql数据库怎么创建数据表并添加数据
赞0答4
MYSQL数据库字段内容如何批量更新
赞0答7
MySQL搜狗百科
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,属于Oracle旗下产品,是最流行的关系型数据库管理系统之一。 MySQL所使用的SQL语言是用于访问数据库的最常用标准化语言,由于其体积小、速度快、开放源码...
新冠肺炎又有新的发现吗?
赞4455
舒兰市为什么在48小时成为高风险地区?
赞3108
纽约州多名儿童感染不明综合征与新冠病毒有关吗?
赞4874
正在加载...
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)