一条sql是如何运行的

本文探讨了SQL查询时客户端与服务器端的交互过程,包括黑盒使用方式、数据库连接创建与销毁的耗时问题,以及连接池(如C3P0、Druid)如何通过复用连接提高效率。服务端会验证用户名和密码等信息。
摘要由CSDN通过智能技术生成

在我们平时使用sql的时候,基本是基于黑盒的使用方式,在客户端输入一条sql语句,然后回显想要的数据,对于mysql server端内部如何运行的以及与存储引擎如何交互的不得而知。

通过下面一幅图,大致描述客户端和服务端交互流程。

交互流程:

1. 在用户发来多个与数据库请求的时候,一个请求就需要创建一个数据库连接进行操作数据,在处理完后进行销毁连接,如此反复。创建和销毁连接会非常耗时,此时会引入一个数据库连接池机制(如C3P0、Druid),通过池化思想,创建完不进行销毁,用完重新放回池子中,可以重复使用。

在获取到数据连接时,可以向服务端发送执行sql的语句,其实是一段文本。

2. 服务端线程监听到客户端发送的sql请求,会进行连接处理,如用户名、密码等相关验证

  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值