- 索引的选择
非空,唯一,经常查询的数据
- 数据库事务
事务就是把多个sql语句当作一个单元执行,如果其中一个语句出现问题,就会立即回滚,恢复到原来的样子。
- 查询语句很慢的原因
是否唯一索引;是否表互联;sql语句是否待优化
-
设置MySQL的long_query_time属性,定义慢查询的超时时间,默认为十秒钟
-
设置属性show_query_log 为on,即开启慢查询语句日志记录,当慢查询sql语句超过long_query_time时,这个sql语句会被写进日志
-
查询日志,确定慢查询sql语句
- MySQL的存储引擎InnoDB和MyISAM的区别
- InnoDB支持事务,MyISAM不支持
- InnoDB支持行锁,MyISAM不支持行锁,他们都支持表锁(InnoDB使用select时where语句不使用主键为索引也会锁表)
- InnoDB适合修改,MyISAM适合查询,插入和删除
- InnoDB查询行数需要遍历一遍,MyISAM本身有字段记录,直接返回结果
- 事务的并发问题
1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据
2、不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果因此本事务先后两次读到的数据结果会不一致。
3、幻读:幻读解决了不重复读,保证了同一个事务里,查询的结果都是事务开始时的状态(一致性)。
例如:事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作 这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。 而操作事务T1的用户如果再查看刚刚修改的数据,会发现还有跟没有修改一样,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。
事务的隔离级别
----------------------------------------------------------
事务隔离级别 脏读 不可重复读 幻读
读未提交 read-uncommitted 是 是 是
不可重复读 read-committed 否 是 是
可重复读 repeatable-read 否 否 是
串行化 serializable 否 否 否
------------------------------------------------------------------------
读未提交:另一个事务修改了数据,但尚未提交,而本事务中的SELECT会读到这些未被提交的数据脏读
不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果因此本事务先后两次读到的数据结果会不一致。
可重复读:在同一个事务里,SELECT的结果是事务开始时时间点的状态,因此,同样的SELECT操作读到的结果会是一致的。但是,会有幻读现象
串行化:最高的隔离级别,在这个隔离级别下,不会产生任何异常。并发的事务,就像事务是在一个个按照顺序执行一样
MySQL默认的事务隔离级别为repeatable-read
MySQL 支持 4 中事务隔离级别.
事务的隔离级别要得到底层数据库引擎的支持, 而不是应用程序或者框架的支持.
Oracle 支持的 2 种事务隔离级别:READ_COMMITED , SERIALIZABLE
补充:
SQL规范所规定的标准,不同的数据库具体的实现可能会有些差异
# 总结
我们总是喜欢瞻仰大厂的大神们,但实际上大神也不过凡人,与菜鸟程序员相比,也就多花了几分心思,如果你再不努力,差距也只会越来越大。实际上,作为程序员,丰富自己的知识储备,提升自己的知识深度和广度是很有必要的。
**[CodeChina开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.youkuaiyun.com/m0_60958482/java-p7)**
# Mybatis源码解析

面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.youkuaiyun.com/m0_60958482/java-p7)**
# Mybatis源码解析
[外链图片转存中...(img-PiVpITAX-1630671742466)]
