MySql学习记录《一》

文章介绍了在JavaEE项目中调用Sql语句的流程,包括依赖MySQL驱动,配置数据库信息,以及使用连接池优化性能。同时,详细讲解了存储引擎的作用,特别是Innodb存储引擎的数据更新流程,包括BufferPool、redo日志和事务提交机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

**

项目中调用Sql语句的流程是怎么样的?

**
在《JavaEE开发技术》中老师课堂上教我们在项目中使用数据库时,第一步肯定是说在pom.xml中依赖MySQL驱动,第二步配置数据库信息,第三步测试。其实MySQL驱动就是用来连接数据库的,类似于建立TCP长连接我们就可以基于这个连接进行发送和解析数据(计算机网络)。
当我们调用向执行sql语句的接口时,首先会与数据库建立连接,然后执行sql语句,接着关闭连接。
在这里插入图片描述
而在数据库方,会有线程去监听连接池,当有请求过来,就会把sql交给sql接口,下一步到sql解析器 解析sql,接着到查询优化器 获得最优查询路径,接着到执行器,执行器会根据查询路径一步步的去调用存储引擎的各个接口。
在这里插入图片描述

为什么常会在项目中db.properties文件中取配置数据库连接池?

  当用户请求我们的项目时,可能是并发的,此时去调用数据库也是并发的,此时如果不用数据库连接池的话,就会在每次需要执行sql语句时,建立一个连接,执行sql语句,再关闭连接。这样消耗性能太大。而连接池可以帮我们把执行完sql语句后的连接不断掉,放在连接池里。等待执行sql语句时接着用。优化了每次建立连接的时间。

在这里插入图片描述

存储引擎的作用?Innodb执行流程是怎么样的?

存储引擎:顾名思义就是通过引擎将数据存储在某种介质中,并且保证数据的正常访问。
比如更新一条sql语句

  1. 执行器会先到内存中的BufferPool找,没找到则去磁盘文件找出来的数 据放在缓冲池中。
  2. 更新undo日志文件
  3. 修改缓冲池中的数据
  4. 更新redo Buffer Pool的日志文件
  5. 提交事务时,把redo日志文件刷入磁盘中,如果开启了binlog,则也将binlog日志写入文件中。
  6. 在磁盘redo日志文件中写入commit标识。
    在这里插入图片描述
    常见问题:
    1. 如果在更改了BufferPool的数据,此时宕机了怎么办?
    无大碍,因为此时事务还没提交,磁盘文件还是原来的值,不 影响业务数据。
    2. 如果提交了事务此时redo log也刷入了磁盘,宕机了怎么办?
    此时宕机了之后如果redo日志文件已经写入了commit标记,则才算 事务提交成功,此时redo日志文件已经保存了更新后的值,将其更新到数 据库磁盘文件即可。

这是本人在学习MySQL的笔记,如有错误,欢迎评论区指导,一起讨论。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值