mysql小记--基础知识
一、事务
二、事务的隔离级别
创建表
CREATE TABLE `class_teacher` (
`id` int() NOT NULL AUTO_INCREMENT,
`class_name` varchar() DEFAULT NULL,
`teacher_id` int() NOT NULL,
PRIMARY KEY (`id`),
KEY `idx_teacher_id` (`teacher_id`)
) ENGINE=InnoDB; 插入数据
insert into class_teacher(class_name, teacher_id) values('class301', ),('class201', ); 根据二级索引进行更新(update或delete),之后进行插入[数据库隔离级别:REPEATABLE-READ]
)、
事务0: update class_teacher set class_name='class202' where teacher_id=; 事务1:insert into class_teacher(class_name,teacher_id) values('class229', );
[插入OK]
事务2:insert into class_teacher(class_name,teacher_id) values('class230', );
[插入WAIT]
事务3:insert into class_teacher(class_name,teacher_id) values('class231', );
[插入WAIT]
事务4:insert into class_teacher(class_name,teacher_id) values('class232', );
[插入WAIT]
事务5:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入WAIT] 结论:
锁定[,无穷大) )、
事务0: update class_teacher set class_name='class202' where teacher_id=; 事务1:insert into class_teacher(class_name,teacher_id) values('class210', );
[插入WAIT]
事务2:insert into class_teacher(class_name,teacher_id) values('class220', );
[插入WAIT]
事务3:insert into class_teacher(class_name,teacher_id) values('class230', );
[插入WAIT]
事务4:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入OK]
事务5:insert into class_teacher(class_name,teacher_id) values('class260', );
[插入OK] 结论:
锁定(无穷小,) )、
事务0: update class_teacher set class_name='class202' where teacher_id=; 事务1:insert into class_teacher(class_name,teacher_id) values('class240', );
[插入WAIT]
事务2:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入WAIT]
事务3:insert into class_teacher(class_name,teacher_id) values('class260', );
[插入WAIT]
事务4:insert into class_teacher(class_name,teacher_id) values('class215', );
[插入WAIT]
事务5:insert into class_teacher(class_name,teacher_id) values('class229', );
[插入WAIT]
事务6:insert into class_teacher(class_name,teacher_id) values('class230', );
[插入OK]
事务7:insert into class_teacher(class_name,teacher_id) values('class231', );
[插入OK] 结论:
锁定(无穷小,]和[,) )、
事务0:update class_teacher set class_name='class202' where teacher_id=; 事务1:insert into class_teacher(class_name,teacher_id) values('class240', );
[插入OK]
事务2:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入WAIT]
事务3:insert into class_teacher(class_name,teacher_id) values('class260', );
[插入WAIT]
事务4:insert into class_teacher(class_name,teacher_id) values('class215', );
[插入WAIT]
事务5:insert into class_teacher(class_name,teacher_id) values('class229', );
[插入WAIT]
事务6:insert into class_teacher(class_name,teacher_id) values('class230', );
[插入WAIT]
事务7:insert into class_teacher(class_name,teacher_id) values('class231', );
[插入WAIT]
事务8:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入WAIT] 结论:
锁定(,]和[,无穷大) )、
事务0: update class_teacher set class_name='class202' where teacher_id=; 事务1:insert into class_teacher(class_name,teacher_id) values('class240', );
[插入OK]
事务2:insert into class_teacher(class_name,teacher_id) values('class250', );
[插入WAIT]
事务3:insert into class_teacher(class_name,teacher_id) values('class260', );
[插入WAIT]
事务4:insert into class_teacher(class_name,teacher_id) values('class215', );
[插入WAIT]
事务5:insert into class_teacher(class_name,teacher_id) values('class229', );
[插入WAIT]
事务6:insert into class_teacher(class_name,teacher_id) values('class230', );
[插入OK]
事务7:insert into class_teacher(class_name,teacher_id) values('class231', );
[插入OK] 结论:
锁定[,)
总结:当是根据二级索引进行更新,如update或delete时,在当前隔离级别下,其都会使用Next-Key锁[a,b)[行锁 + gap锁]前闭后开的,无法进行插入。
备注:
Repeatable Read,当使用非索引字段进行更新时,则会进行表锁。
Read Uncommitted,数据库一般不用,且在其上的任何操作都不会加锁。
Read Committed,有Record锁,没有Next-Key锁,即Next-Key锁变成了Record锁。
mysql小记--基础知识的更多相关文章
- MySQL数据库基础知识及优化
MySQL数据库基础知识及优化必会的知识点,你掌握了多少? 推荐阅读: 这些必会的计算机网络知识点你都掌握了吗 关于数据库事务和锁的必会知识点,你掌握了多少? 关于数据库索引,必须掌握的知识点 目录 ...
- Mysql之基础知识笔记
Mysql数据库基础知识个人笔记 连接本地数据库: mysql -h localhost -u root -p 回车输入数据库密码 数据库的基础操作: 查看当前所有的数据库:show database ...
- 阿里面试官必问的12个MySQL数据库基础知识,哪些你还不知道?
数据库基础知识 1.为什么要使用数据库 (1)数据保存在内存 优点: 存取速度快 缺点: 数据不能永久保存 (2)数据保存在文件 优点: 数据永久保存 缺点: 1)速度比内存操作慢,频繁的IO操作. ...
- MySQL:基础知识
基础知识 一.软件的生命周期 软件定义 软件开发 软件使用与维护 二.数据(Data) 1.定义 描述客观事物特征或性质的某种符号,经过数字化处理存储在计算机 2.数据独立性 物理独立性:指用户的应用 ...
- MySQL学习基础知识1
什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...
- [mysql]数据库基础知识
数据库管理系统DBMS 软件 bin config db (保存数据) 写程序: 数据库在本地 找到目录 添加数据 数据库在远程 socket连接上远程机器 socket发送命令 需要做的事情 程序 ...
- MySQL学习基础知识2
1.基础语句 查 select(* | 字段名 | 四则运算 | 聚合函数) from 表名称; 加上as取别名 as可省略 如:select name, (math+english)/2 total ...
- Java基础86 MySQL数据库基础知识
本文知识点(目录): 1.MySQL数据库的概述 2.MySQL数据库的管理[对数据库的操作](查询.删除.创建数据库,以及查询和修改数据库的编码模式) 3.表的管理[对数据库 表的操作] ...
- python week09 Mysql 数据库基础知识
第一篇:初识数据库 注:<基础概念,不再赘述,点开链接查看> 第二篇:库相关操作 一 系统数据库 information_schema: 虚拟库,不占用磁盘空间,存储的是数据库启动后的一些 ...
随机推荐
- ADO.NET笔记——使用连接池
相关知识: 连接池的意义: 应用程序往往涉及大量的,并发的数据访问操作 数据库服务器能够同时维系的连接数量非常有限.如果某个数据库访问操作不及时关闭连接,就会减少其他调用对数据库访问的机会.因此,一般 ...
- shell 字符截取
Linux 的字符串截取很有用.有八种方法. 假设有变量 var=http://www.aaa.com/123.htm. # 读sharp 谐音 杀: ${var#*//} 杀掉//左边的,保留右边的 ...
- 高德amap 根据坐标获取的地址信息
高德地理逆地理编码接口List<List<Address>> lists = coder.getFromLocation(33.00, 116.500, 3, 3, 3, 50 ...
- fast_recovery_area无剩余空间(ORA-19815)
一.问题现象 --执行日志切换时,夯住 SQL ('/u01/oradata/oracle/redo04.log') size 50m; SQL> alter system switch log ...
- python之递归
递归的定义:即对自己自身内容的引用. 有用的递归函数应包含以下几步份: 当函数直接返回值时有基本的实例(最小可能性问题): 递归实例,包括一个或者多个问题较小部分的递归调用: 递归的关键就是将问题分解 ...
- 在Linux下写一个简单的驱动程序
本文首先描述了一个可以实际测试运行的驱动实例,然后由此去讨论Linux下驱动模板的要素,以及Linux上应用程序到驱动的执行过程.相信这样由浅入深.由具体实例到抽象理论的描述更容易初学者入手Linux ...
- TCP/IP, HTTP, socket
摘自:http://jingyan.baidu.com/article/08b6a591e07ecc14a80922f1.html http://goodcandle.cnblogs.com/arch ...
- 非常实用的10个PHP高级应用技巧
PHP 独特的语法混合了 C.Java.Perl 以及 PHP 自创新的语法.它可以比 CGI或者Perl更快速的执行动态网页.用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML ...
- sharepoint 认证
MCPD http://www.microsoft.com/learning/en/us/mcpd-certification.aspx#fbid=YktyKIYXeFg Exam 70-573: T ...
- CSS去除Chrome浏览器的控件默认样式
html的input输入框在Chrome浏览器里是有默认样式的,当它获得焦点时,即使你没有为它设置:focus时的样式,Chrome浏览器还是会给它加上蓝色的边框,今天百度找到有个方法可以去除该默认样 ...