三范式,Java面试知识点

  1. 索引的选择

非空,唯一,经常查询的数据

  1. 数据库事务

事务就是把多个sql语句当作一个单元执行,如果其中一个语句出现问题,就会立即回滚,恢复到原来的样子。

  1. 查询语句很慢的原因

是否唯一索引;是否表互联;sql语句是否待优化

数据库慢查询sql语句定位


  1. 设置MySQL的long_query_time属性,定义慢查询的超时时间,默认为十秒钟

  2. 设置属性show_query_log 为on,即开启慢查询语句日志记录,当慢查询sql语句超过long_query_time时,这个sql语句会被写进日志

  3. 查询日志,确定慢查询sql语句

数据库学习2


  1. MySQL的存储引擎InnoDB和MyISAM的区别
  1. InnoDB支持事务,MyISAM不支持
  1. InnoDB支持行锁,MyISAM不支持行锁,他们都支持表锁(InnoDB使用select时where语句不使用主键为索引也会锁表)
  1. InnoDB适合修改,MyISAM适合查询,插入和删除
  1. InnoDB查询行数需要遍历一遍,MyISAM本身有字段记录,直接返回结果
  1. 事务的并发问题

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://img-blog.csdnimg.cn/img_convert/23726cffd8066f8097967410b5058011.png)

面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.youkuaiyun.com/m0_60958482/java-p7)**

# Mybatis源码解析



[外链图片转存中...(img-PiVpITAX-1630671742466)]

![](https://img-blog.csdnimg.cn/img_convert/d053abd1ceba91fed1fb9c1c9f1d50ab.png)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值