1、连接数据库
2、Mysql驱动:mysql-connector-java
与数据库通讯就必须得建立网络链接,网络链接就是由Mysql驱动来建立的
3、数据连接池到底用来干嘛的?
常见的数据库连接池有:DBCP,C3P0,Druid等
4、Mysql本身也有连接池
5、SQL语句执行流程(MYSQL内部架构):
1、工作线程:网络必须得分配给一个线程来处理,由一个线程来监听以及读取请求数据;
2、SQL接口:SQL接口就是SQL interface,用于执行SQL语句;
3、解析器:解析SQL为MYSQL可以理解的执行步骤;
Select id,name,age from users where id = 1;
解析为:
从users表中查询数据;查询id=1的那条数据;对查询出来的数据提取里面的id,name,age字段。
4、优化器:选择最优的查询路径;
选择一条最优的查询路径,也就是代价最小的执行计划,比如:可能会调整执行步骤什么的
5、执行器:调用存储引擎接口,真正地去执行SQL;
执行器根据最优的执行计划去调用存储引擎的接口,去执行
6、存储引擎:储存引擎解决的问题是根据指令,去操作内存缓存、磁盘。
Mysql内部架构_jerry_dyy的博客-CSDN博客
Mysql存储模型_jerry_dyy的博客-CSDN博客
InnoDB内部架构_jerry_dyy的博客-CSDN博客
Buffer Pool 核心原理_jerry_dyy的博客-CSDN博客
Buffer Pool生产实践_jerry_dyy的博客-CSDN博客
Mysql事务隔离机制_jerry_dyy的博客-CSDN博客
Mysql的锁机制_jerry_dyy的博客-CSDN博客
Mysql的索引深度讲解_jerry_dyy的博客-CSDN博客
Mysql索引的使用_jerry_dyy的博客-CSDN博客
SQL语句的执行计划_jerry_dyy的博客-CSDN博客_sql语句的执行计划