首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL执行sql语句机制

目录 1 概念 2 执行过程 1 概念 连接器: 身份认证和权限相关(登录 MySQL 时候)。...查询缓存: 执行查询语句时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。...分析器: 没有命中缓存的话,SQL 语句就会经过分析器,分析器说白了就是要先看你 SQL 语句要干嘛,再检查你 SQL 语句语法是否正确。...第二步,语法分析,主要就是判断你输入 sql 是否正确,是否符合 MySQL 语法。 优化器: 按照 MySQL 认为最优方案去执行执行器: 执行语句,然后从存储引擎返回数据。...2 执行过程 查询语句执行: 1、鉴权 2、查询缓存 3、分析sql,提取关键字select 、表名、列字段、查询条件,然后判断语法 4、优化执行方案,自己优化算法不一定是最优 5、再次权限校验

3.8K30

MySqlsql语句执行过程详述

前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句执行过程是怎样,如果不了解执行过程的话,就很难进行sql语句优化处理,也很难设计出来优良数据库表结构。...这篇文章主要是讲解一下sql语句执行过程。 sql语句执行过程: 客户端、连接器、分析器、优化器、执行器、存储引擎几个阶段。 连接器作用:管理链接、权限验证处理。...查询缓存: 连接建立完毕之后,进行查询缓存处理,执行sql语句会先到缓存中看看是不是刚刚执行了这条语句,之前执行语句及其结果就会以key-value对形式直接存储在内存中,key是查询语句,...分析器: 分析器首先会进行词法分析,输入是由多个字符串和空格组成一条sql语句mysql需要识别出来里面的字符串分别是什么,代表什么意思。...然后进行语法分析处理,根据词法分析,根据词法分析结果,语句分析器就会根据语法规则判断输入这个sql语句是否满足mysql语法。

22240
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL查看实时执行SQL语句

MySQL默认不能实时查看执行SQL语句,因为这会消耗一定资源。 要开启这个功能,稍微配置一下,打开这个LOG记录就可以了。 1 查看LOG功能 首先,查看是否已经开启实时SQL语句记录。...语句功能,并指定自定义log路径: mysql> SET GLOBAL general_log = 'ON'; mysql> SET GLOBAL general_log_file = '/var/...2.2 永久开启 永久有效需要配置my.cnf文件,加入下面两行: general_log = 1 general_log_file = /var/log/mysql/general_sql.log 重启...3 实时查看 过一小段时间后,就可以导出查看/var/lib/mysql/sql_statement.log文件了,里面记录了所有执行SQL语句。...如果要实时查看该文件改动,在Linux系统用tail命令: $ tail -f /var/lib/mysql/general_sql.log 另外,也可以用BareTail软件实时查看。

5K20

MySQL执行SQL语句过程详解

开发人员基本都知道,我们数据存在数据库中(目前最多MySQL和Oracle,由于作者更擅长MySQL,所以这里默认数据库为MySQL),服务器通过sql语句将查询数据请求传入到MySQL数据库。...流程概述   MySQL得到sql语句后,大概流程如下:   1.sql解析器:负责解析和转发sql   2.预处理器:对解析后sql树进行验证   3.查询优化器:得到一个执行计划   4.查询执行引擎...2.结果输出时候,需要额外进行数据缓存操作。   3.写入数据时,MySQL会将对应表所有缓存都设置为失效。当缓存内存较大时候,会导致系统消耗较大。...sql解析器与预处理   sql解析器是在命令分发之后,将对应sql语句,解析为sql解析树。sql解析树是MySQL本身内部语法规则和解析查询。...执行完成后,将结果返回给客户端,如果是查询语句,并且开启了缓存,那么,MySQL会同时将结果集放到查询缓存中。然后将查到结果集返回。如果是增删改操作,那么返回执行语句后受影响行数。

3.5K20

Sql语句Mysql执行流程

查询缓存: 执行查询语句时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。    ...分析器: 没有命中缓存的话,SQL 语句就会经过分析器,分析器说白了就是要先看你 SQL 语句要干嘛,再检查你 SQL 语句语法是否正确。   ...优化器: 按照 MySQL 认为最优方案去执行。   执行器: 执行语句,然后从存储引擎返回数据。   ...连接建立后,执行查询语句时候,会先查询缓存,MySQL 会先校验这个 sql 是否执行过,以 Key-Value 形式缓存在内存中,Key 是查询预计,Value 是结果集。...3) 分析器             MySQL 没有命中缓存,那么就会进入分析器,分析器主要是用来分析 SQL 语句是来干嘛,分析器也会分为几步:             第一步,词法分析,一条 SQL

4.6K10

django执行原生sql_mysql语句执行顺序

大家好,又见面了,我是你们朋友全栈君。...前言 Django在查询数据时,大多数查询都能使用ORM提供API方法,但对于一些复杂查询可能难以使用ORMAPI方法实现,因此Django引入了SQL语句执行方法,有以下三种执行方式 extra...raw:执行原始SQL并返回模型实例对象。...execute:直接执行自定义SQL 以上3种方式,这里只介绍raw方式,用最多,也最推荐使用 raw 只能实现数据查询操作,并且要依靠模型对象,在Pycharm里打开raw源码,如下图所示,它一共定义了...4个参数,每个参数如下: raw_query:SQL语句 params:如果raw_query设置字符串格式化%s,那么该参数为raw_query提供数值 translations:为查询字段设置别名

3.2K10

关于sqlMySQL语句执行顺序(必看!!!)

请认真看完此文章,对你sql一定会有很大提升! ql和mysql执行顺序,发现内部机制是一样。最大区别是在别名引用上。...一、sql执行顺序 (1)from (3) join (2) on (4) where (5)group by(开始使用select中别名,后面的语句中都可以使用) (6) avg,sum...二、mysql执行顺序 SELECT语句定义 一个完成SELECT语句包含可选几个子句。...SELECT语句执行顺序 SELECT语句中子句执行顺序与SELECT语句中子句输入顺序是不一样,所以并不是从SELECT子句开始执行,而是按照下面的顺序执行: 开始->FROM子句->WHERE...就跳过 对比了一下,mysqlsql执行顺序基本是一样, 标准顺序 SQL 语句为: select 考生姓名, max(总成绩) as max总成绩 from tb_Grade where

2.9K40

SQLMysql中一条sql语句执行过程

接下来,通过一条sql语句执行来深入了解MySQL各个组件功能以及其作用。...一、SQL语句执行流程 1、连接MySQL 通常我们会编写sql语句通过某个客户端来执行并且接受执行结果,比如命令行、JDBC、navicat。...3、解析SQL语句 在经过缓存后,就由「解析器」开始工作了,解析器目的是检查sql语句是否正确以及将sql语句解析成MySQL能够理解结构,也就是sql语法树。...一条查询SQL语句执行流程: 客户端通过连接器连接MySQL服务。 连接成功后向SQL接口发送SQL语句请求。...2.2 更新语句 以上就是一条查询 sql 执行流程,那么接下来我们看看一条更新语句如何执行呢?

28410

MySQL:一条SQL语句执行过程

大多数时候不建议使用缓存,因为只要一个表更新,这个表上所有缓存数据就会被清空了。对于那些经常更新表来说,缓存命中率很低。MYSQL8版本直接将查询缓存整块功能删掉了。...第三步:分析器 分析器首先会做“词法分析”,MYSQL会识别出SQL语句里面的字符串是什么以及代表什么。接下来就是“语法分析器”,分析SQL语法问题。...第四步:优化器 优化器会对SQL执行顺序,使用哪个索引进行优化。确定SQL执行方案。 第五步:执行执行执行SQL语句会对权限进行校验,如果有权限,就打开表继续执行。...打开表时候,执行器就会根据表引擎定义,去使用这个引擎提供接口。 图片 一条update语句执行流程 update语句除了会执行上面的五步,还会涉及两个重要日志模块。...更新语句内部流程 update t set n = n+2 where id =1 执行器先找引擎找到id=1那一行,如果这一行数据页已经在内存中则直接返回给执行器。

21120

MySQL数据库:SQL语句执行过程

一、客户端MySQL驱动: 我们系统在和 MySQL 数据库进行通信前,需要先和数据库建立连接,而这个功能就是由MySQL驱动底层帮我们完成,建立完连接之后,我们只需要发送 SQL 语句就可以执行...二、MySql架构Server层: 在介绍MySQL数据库中SQL语句在Server执行步骤前,我们先了解下MySQL整体架构: 如果上图不清楚,可以再看看下面的图: 通过上面的架构图可以得知...;只要是统计分析出来,那就可能会存在分析错误情况,所以在SQL执行不走索引时,也要考虑到这方面的因素 MySql执行计划怎么查看呢?...在执行SQL语句前添加上 explain 关键字即可; 5、执行器: MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。...中,如下图 UPDATE students SET stuName = '小强' WHERE id = 1 比如这条SQL,按照上面的那幅图,SQL 语句执行步骤大致是这样子: (1)innodb

3.5K10

SQL语句MySQL中是如何执行

mysql> select * from T where ID=10; 开门见山,当我们输入一条 SQL 语句时候,MySQL 内部究竟执行了什么?...接下来我们来说明上文 SQL 语句到底在内部经历了什么。 连接器 第一步,客户端会先连接到数据库,这个时候就是连接器来接待。它负责跟客户端建立连接、获取权限、维持和管理连接。...MySQL 拿到一个查询语句,会先查询缓存,先校验这个语句是否执行过,以 key-value 形式存在内存里, Key 是查询预计,Value 是结果集。...分析器 如果没有命中缓存,那么就进入分析器,主要就是分析 SQL 语句是拿来干嘛,也就是解析该语句生成语法树,会分为两步: 第一步:词法分析, 一条 SQL 语句有多个字符串组成,首先要提取关键字,比如...第二步:语法分析,主要就是判断你输入 SQL 是否正确,是否符合 MySQL 语法。,主要就是判断你输入 SQL 是否正确,是否符合 MySQL 语法。

4.3K20

关于sqlMySQL语句执行顺序(必看!!!)

目前还在查看,但是在查阅资料时发现了一些有益知识,给大家分享一下,就是关于sql以及MySQL语句执行顺序: sqlmysql执行顺序,发现内部机制是一样。最大区别是在别名引用上。...一、sql执行顺序 from join on where group by(开始使用select中别名,后面的语句中都可以使用) avg,sum…....二、mysql执行顺序 1、SELECT语句定义 一个完成SELECT语句包含可选几个子句。...2、SELECT语句执行顺序 SELECT语句中子句执行顺序与SELECT语句中子句输入顺序是不一样,所以并不是从SELECT子句开始执行,而是按照下面的顺序执行: 开始->FROM子句-...,就跳过 对比了一下,mysqlsql执行顺序基本是一样, 标准顺序 SQL 语句为: select 考生姓名, max(总成绩) as max总成绩 from tb_Grade where

1.5K30

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行每个过程,才能更好进行SQL设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...当判断缓存是否命中时,MySQL不会进行解析查询语句,而是直接使用SQL语句和客户端发送过来其他原始信息。所以,任何字符上不同,例如空格、注解等都会导致缓存不命中。  ...解析和预处理  解析器通过关键字将SQL语句进行解析,并生成对应解析树。MySQL解析器将使用MySQL语法规则验证和解析查询。  ...如果在一条SQL语句执行过程中将该语句对应最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存执行计划,从而跳过SQL语句生成执行计划整个过程,进而可以提高语句执行速度。

1.8K30

MySQL探秘(二):SQL语句执行过程详解

昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行每个过程,才能更好进行SQL设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...当判断缓存是否命中时,MySQL不会进行解析查询语句,而是直接使用SQL语句和客户端发送过来其他原始信息。所以,任何字符上不同,例如空格、注解等都会导致缓存不命中。  ...解析和预处理  解析器通过关键字将SQL语句进行解析,并生成对应解析树。MySQL解析器将使用MySQL语法规则验证和解析查询。  ...如果在一条SQL语句执行过程中将该语句对应最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存执行计划,从而跳过SQL语句生成执行计划整个过程,进而可以提高语句执行速度。

5.3K10

MySQL使用技巧: 如何查看mysql正在执行SQL语句

MySQL使用技巧: 如何查看mysql正在执行SQL语句 背景: 最近项目开发用到MySQL,想要查看后台执行sql语句,立马google得知、可以使用 show processlist; 命令来解决...,通过里面输出结果字段解释中可以分析执行sql语句类型,但发现不太适合一般初级使用者,而通过日志文件查看sql语句是最直接方法。.../log.txt1    log=d:/mysql/data/log.txt 3:如此就可以记录所有的mysql执行sql语句!  ...state列,显示使用当前连接sql语句状态,很重要列,后续会有所有的状态描述,请注意,state只是语句执行某一个状态,  一个sql语句,已查询为例,可能需要经过copying to tmp...table,Sorting result,Sending data等状态才可以完成,   info列,显示这个sql语句,因为长度有       限,所以长sql语句就显示不全,但是一个判断问题语句重要依据

5.7K20
领券