1.springBoot的自动配置
- 主方法的springBootAoolication注解中的EnableAutoConfiguration
- EnableAutoConfiguration注解中的Import导入的AutoConfigurationImportSelector
- AutoConfigurationImportSelector类中的selectImports方法
- selectImports方法通过内部的一些方法最后找到springFactoryLoader类的laodFactoryNames方法
- 然后就记载springBoot项目本身和依赖包中的spring.factories配置文件
- 依次读取文件信息,加载对象到容器中
2.mysql的索引及索引失效
- 索引一共有四种类型,单列索引、唯一索引、主键索引、聚集索引
- 普通索引,最基本的索引类型(一般使用在where,order by,group by之后,通过建立单个字段的索引),没有唯一性索引的限制(可重复索引),使用INDEX关键字进行创建索引
- 唯一索引,不允许数据表中出现两行具有相同索引值,使用UNIQUE关键字进行创建索引
- 主键索引,简称主索引,数据库表中一列或列组合(字段)的值唯一标识表中的每一行。称为表的主键。这个索引要求主键中的每个值都是唯一。尽量使用主键索引
- 聚集索引,也称为聚簇索引。指索引项的排序方式和表中数据记录的排序方式一致。聚集索引并不是一种单独的索引类型,而是一种数据存储方式。因为数据在物理存放时只能有一种排列方式,所以一个表只能有一个聚集索引。除聚集索引以外的索引都是普通索引,即非聚集索引
- 非聚集索引,指索引项的排序方式和表中数据记录的排序方式不一致。一个表中只能有一个聚集索引,但表中的每一列都可以有自己的非聚集索引
- 索引失效
- 查询条件使用or时,其中一个条件本身不是索引,导致另一个索引查询失效
- 查询条件使用like时,模糊查询失效
- 查询条件的数值是字符串时,不带有双引号,索引失效
- 查询条件进行计算时,索引失效
- 查询条件违背最左侧前缀,索引失效
3.线程池的参数及参数的意义、工作方式
- corePoolSize,常驻核心线程数量(先使用核心线程)
- maximumPoolSize&#x