1.1 if 语句 1.1.1 语法 # 当条件表达式为 true 的时候,返回 值1,否则返回 值2 if(条件表达式, 值1, 值2); # 类似 java 中的 if ··· else if...后面 case 可以省略 1.2.2 示例 # 第一种用法 # 类似 java 中的 switch ··· case mysql> select id as '编号',(case sex when 1...3 | 女 | 小姐姐 | | 4 | 男 | 牛魔王 | +------+------+--------+ 4 rows in set (0.20 sec) # 类似 java 中的...☞ 循环控制 # 类似 java中的 continue iterate 循环标签; # 类似 java 中的 break leave 循环标签; ☞ 示例 # 求 1 ~ n 的和 # 创建存储过程...procedure if exists sumnum; Query OK, 0 rows affected (0.07 sec) 1.3.3 repeat 循环 repeat 循环类似于 java 中的
查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。 ...优化器: 按照 MySQL 认为最优的方案去执行。 执行器: 执行语句,然后从存储引擎返回数据。 ...2) 查询缓存(MySQL 8.0 版本后移除) 查询缓存主要用来缓存我们所执行的 SELECT 语句以及该语句的结果集。 ...连接建立后,执行查询语句的时候,会先查询缓存,MySQL 会先校验这个 sql 是否执行过,以 Key-Value 的形式缓存在内存中,Key 是查询预计,Value 是结果集。...MySQL 查询不建议使用缓存,因为查询缓存失效在实际业务场景中可能会非常频繁,假如你对一个表更新的话,这个表上的所有的查询缓存都会被清空。
学习了极客时间MySql课程,做个总结 以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程 一条sql语句在执行过程中需要经过连接器、分析器、优化器、...当你输入了用户名和密码后,连接器会在权限表中查询你拥有的权限,之后本次连接中你对表能否操作查询删除修改等,都依赖于此时读取到的权限。...查询缓存 在经过连接器之后,会执行第二步查询缓存,在MySql拿到查询后,会先到查询缓存查看是否执行过这条语句,之前执行的结果会以key-value对的形式存在,如果不在查询缓存中,会继续执行后面的极端...在MySql8.0之后去掉了查询缓存的功能。...分析器 分析器会先做“词法分析”,识别出sql里的字符串分别是什么,读出“select”关键字对出这是一条查询语句,把字符串T识别成“表T” “语法分析”,根据词法分析的结果,判断该条sql是否满足MySql
目录: 选择结构 if函数 if结构 case结构 循环结构 while loop repeat 流程控制语句大致分为选择结构与循环结构;...if结构 功能:实现多路选择 注意:只能用在begin...end结构体中 语法: if 逻辑表达式 then 语句1; elseif 逻辑表达式2 then 语句2; ... else 语句n; end...while; 注意:在do...end while中写循环体; 代码实例: 创建存储过程,输入一个值,返回1到该值的和; delimiter $ create procedure pro_sum...call pro_sum(2,@result); select @result; loop 语法: 循环名称:loop; if 逻辑表达式 then leave 循环名称; #跳出当前指定的循环...,类似于Java中的break; end if; end loop; 代码实例: #创建存储过程 DELIMITER // CREATE PROCEDURE pro_sum_loop(IN input
官方的图 ---- ? 自行画的图 ---- ? 第一步: 连接器 首先我们要连接上这个数据库,连接器负责建立连接,判断认证是否通过等。...第二部: 查询缓存 mysql拿到请求后首先判断请求的查询语句是否有缓存,是否命中缓存,但是不推荐使用mysql的缓存,官方也不推荐,因为只要有一条数据更新表的缓存就会被删除,降低效率 第三步: ...分析器 没有命中缓存的话就要开始执行语句了,首先对sql语句进行解析, 首先做 “词法解析”,分析出sql语句的关键词等字符串代表什么含义,然后通过”语法分析“判断这个sql是否满足语法标准。...第四步: 优化器 优化sql执行的速度,比如执行的索引、表连接(join)的执行顺序,然后决定出最快的执行方案 第五步: 执行器 判断用户对这个表是否有权限,有的话就会根据这个表的引擎执行通过优化器给出的最优执行方案去执行
连接器连接流程 mysql -hip -Pport -uuser -p 是一个连接到 MySQL 服务器的命令,其中 ip 是要连接的 MySQL 服务器的主机名或 IP 地址,port 是 MySQL...此时,我们可以在命令行中输入 SQL 语句,并将其发送给 MySQL 服务器进行执行。 MySQL 服务器接收到 SQL 语句后,会执行相应的操作,比如查询、插入、更新等。...它可以在执行查询语句时,将查询结果缓存到内存中,以便后续相同的查询可以直接从缓存中获取结果,而不需要再次执行相同的查询操作。...MySQL 查询缓存的优点包括: 提高查询性能:对于相同的查询语句,可以直接从缓存中获取结果,避免了再次执行查询的开销,提高了查询性能。...t where ID=1' at line 1 优化器 什么是 MySQL 优化器 MySQL 优化器(MySQL Optimizer)是 MySQL 数据库中的一个组件,负责分析和优化查询语句的执行计划
好了,今天我们就一起来聊聊select语句是如何在MySQL中执行的。文章的主要内容如下。 ?...select * from user where user_id = 1001; 当我们在MySQL的命令行中输入上述SQL语句时,这条SQL语句到底在MySQL中是如何执行的呢?...接下来,我们就以这条SQL语句为例,说说select语句是如何在MySQL中执行的。...MySQL逻辑架构 在介绍select语句在MySQL中的执行流程之前,我们先来看看MySQL的逻辑架构,因为任何SQL语句的执行都离不开MySQL逻辑架构的支撑。...也就是说,SQL语句在MySQL中的执行流程与MySQL的逻辑架构是密不可分的。 ? 在上图中,我们简单的画了下MySQL的逻辑架构图,并且给出了逻辑分层和每层中各部分的功能。
MySQL中的join语法 在MySQL中,join语句想必大家都不陌生,今天我们围绕join语句展开,说一些可能平时不关注的知识点。...整个join语句的执行过程如下: a、从表t1中拿到一条记录的字段a值 b、拿a的值去t2表中查找,查找匹配的行 c、找到结果,和表t1中的行拼接成一行记录,作为结果的一条记录 d、重复以上三个步骤,直到...在这个过程中,因为t2表使用到了索引,而且执行的过程是循环执行的,所以MySQL把这种情况下的join查询称之为index Nested-Loop join。...这里,我们简单推一下复杂度的公式: 假设驱动表的记录为M,被驱动表的值是N,因为被驱动表使用了索引,在一棵b+树上索引的查找效率近似logN,因为我们的语句时select * ,要牵扯到回表到聚集索引查询所有字段...最后介绍下,MySQL中通过下面的参数来控制join buffer的大小: mysql> show variables like '%join_buffer%'; +------------------
我们可以在存储过程和函数中实现比较复杂的业务逻辑,但是需要对应的流程控制语句来控制,就像Java中分支和循环语句一样,在MySQL中也提供了对应的语句,接下来就详细的介绍下。...语句结构 说明 顺序结构 程序从上往下依次执行 分支结构 程序按条件进行选择执行,从两条或多条路径中选择一条执行 循环结构 程序满足一定条件下,重复执行一组语句 针对于MySQL 的流程控制语句主要有...这里“[]”中的内容是可选的。...ELSE 结果n或语句n(如果是语句,需要加分号) END [case](如果是放在begin end中需要加上case,如果放在select后面不需要) CASE语句的实际案例 # CASE 语句...WHILE语句的基本格式如下: Java中的while语句 while(条件表达式){ // 循环体 } MySQL中的WHILE语句 [while_label:] WHILE 循环条件 DO
MySQL中SQL语句的索引分析 了解过 索引 的概念以及 B+树 的概念之后,我们就来看看怎么分析一条查询语句的索引使用情况。...相信不少同学应该都使用过 EXPLAIN 来分析 SQL 语句,但是具体到 EXPLAIN 中每个字段的作用,可能有不少同学还是会有点晕的。...EXPLAIN语句 接下来,我们使用 EXPLAIN 来查看这条语句。...目前,我们的表中没有建立任何索引,只有一个主键索引,因此,上面的查询中,大部分的分析结果都是 NULL ,同时 rows 显示的行数也是全部数据的数量,也就是说,在没走索引的情况下,现在我们的查询是一个全表扫描...参考文档: 《MySQL是怎样运行的》
java中的流程控制语句总共有三种,分别是顺序结构,分支结构和循环结构 1. 顺序结构: 没什么好说的,代码从前往后依次执行 2....如果是false就不执行语句体 第二种形式: if(关系表达式) { 语句体1; }else { 语句体2; } 执行流程...执行流程: 首先计算出表达式的值 其次,和case依次比较,一旦有对应的值,就会执行相应的语句,在执行的过程中,遇到break就会结束。.....while 如下代码是死循环 while(true){} for(;;){} 好了,关于三大流程控制语句的语法我们就介绍到这里...,后边我们会介绍一些使用流程控制语句实现的具体案例。
Mysql中的条件语句在我们对数据进行转换的时候比较有用,这样就不需要创建中转表。...= "" IF ELSE 流程控制语句 在mysql存储过程中的用法: IF search_condition THEN statement_list [ELSEIF search_condition...[ELSE statement_list] END IF IF作为一条语句,在END IF后需要加上分号“;”以表示语句结束,其他语句如CASE、LOOP等也是相同的。...= '' Swap Salary Leetcode中有一道题目就是根据条件来转换数据的,就需要用条件控制语句来实现。...参考资料: 1、Mysql if case总结 2、Leetcode swap salary 3、select case when if 的一些用法 4、IF Syntax
DML 的执行流程 如果你对 MySQL 的这两个日志没有了解过的话,上面的特性是很难理解的,如果结合着 DML 语句执行流程就会好理解一点,比如我现在要在数据库的表中更新 id = 1 这一行中的 value...主要的流程如下,MySQL会从内存中获取相应的数据行(如果没有先从磁盘 load 到内存中),然后将数据行进行更新并将新行写入内存后进行redo log的写入和 bin log 的写入,在一开始 redo...你可以想一下,一个事务会有多个 DML 语句,而每次 DML 语句都进行写盘会进行大量的系统调用导致资源浪费和时间浪费,所以每次 DML 语句的时候只是会将 日志先缓存到内存中的 redo log buffer...对于这个问题就可以总结为两点: 通过日志的顺序写提高磁盘效率 通过组提交减少系统调用 总结 这里我们主要介绍了在 MySQL 中 一条 DML 语句是如何执行的,redo log 、bin log又是如何和...总的来说就是 MySQL 在进行 DML 语句的时候会先写日志缓存(为了事务多个 DML 语句而不多次进行写盘操作),等到事务提交的时候会进行日志的真正落盘(“双一配置”),其中还使用了两阶段提交加上redo
其中最基本的就是if语句和switch语句,这两种语句都可以用于根据不同的条件执行不同的代码块。在日常开发中,对于一些需要基于条件来进行判断和控制的业务逻辑,if和switch语句都是必不可少的工具。...摘要 本文主要围绕JavaSE中的条件语句:if语句、switch语句进行介绍和解析。...在介绍的同时,我们还会结合实际的应用场景,解析if和switch语句的优缺点,以及在类中定义if和switch语句的方法和标准等。...在这段代码中,使用了if-else语句来进行条件判断,当num大于0时,执行if语句块中的代码,即输出"num是正数。";否则执行else语句块中的代码,即输出"num是负数或0。"。...类代码方法介绍定义if语句 在类中定义if语句的方法非常简单,只需要根据语法要求编写if语句即可。
这篇笔记主要记录MySQL的基础架构,一条查询语句是如何执行的。...比如,在我们从student表中查询一个id=2的信息 select * from student where id=2; 在解释这条语句执行流程之前,我们看看MySQL的基础架构。...执行语句的时候,mysql首先是去查询缓存,之前有没有执行过这样的语句,mysql会将之前执行过的语句和结果以key-value的形式存储起来(当然有一定的存储和实效时间)。...中称之为比较能反映性能提升的指数,一般来说达到3:1则算是查询缓存有效,而最好能够达到10:1 分析器 在查询缓存实效或者是无缓存的时候,这个时候MySQL的server就会利用分析器来分析语句,分析器也叫解析器...总结 MySQL得到sql语句后,大概流程如下: 0.连接器负责和客户端进行通信 1.查询缓存:首先查询缓存看是否存在k-v缓存 2.解析器:负责解析和转发sql 3.预处理器:对解析后的sql树进行验证
student); [Err] 1093 - You can't specify target table 'student' for update in FROM clause 描述: 如果子查询的...解决方法: 通过给 from 子句中的结果集起别名。...student m where m.id = 1; [Err] 1064 - You have an error in your SQL syntax; 描述: delete from table 这样的句子中
对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本。本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考。...对于脚本输出的结果美化,需要进一步完善和调整。以下为具体的示例及其方法。...1、将SQL语句直接嵌入到shell脚本文件中 --演示环境 [root@SZDB ~]# more /etc/issue CentOS release 5.9 (Final) Kernel \r on...file '/tmp/temp.log' id val 1 jack 2 robin 3 mark Outfile disabled. 4、shell脚本中MySQL.../shell_call_sql4.sh Current count is : 1 #以上脚本演示中,作抛砖引玉只用,对于输出的结果不是很规整友好,需要进一步改善和提高。
流程控制就是对事物次序的布置和安排,在程序中就是对代码执行次序的安排和控制 程序中的流程控制主要有三种:顺序流程、选择流程、循环流程。...顺序流程:比如打印输出的代码按照指定的顺序结构依次排序,打印的结果按照代码的顺序执行打印; 循环流程:选择结构的代码实现; 循环流程:循环结构的代码实现; 一、顺序结果 顺序结构最容易理解也比较简单,执行顺序就是代码编写的顺序...System.out.println(2); System.out.println(3); } 输出: 1 2 3 二、选择结构 Java代码中存在一种特殊的语句,叫做选择语句,这种选择语句也需要对一些条件作出判断...执行流程: 首先计算出表达式的值 其次,和case依次比较,一旦有对应的值,就会执行相应的语句,在执行的过程中,遇到break就会结束。...和选择结构中的if判断也有点类似,满足条件就执行 {} 内的语句,区别在于while语句会反复地执行,知道条件不成立。 执行流程: 执行顺序:①②③④>②③④>②③④…②不满足为止。
JavaScript定义了一组语句,语句通常用于执行一定的任务。语句可以很简单,也可以很复杂。 选择结构,可以在程序中创建交叉结构来指定程序流的可能方向。...5:3;此时result=5; 4.多选结构(switch) switch语句与if语句相似,也是常用的流程控制语句。...break; } var x=99; switch(true){ case x<60: console.log("差"); break; case x>=60&&x<80: console.log("中"...循环语句包括do-while,while,for,for-in. do-while语句,在循环表达式的最后测试表达式的条件,也就是说do-while语句至少会执行一次。...for-in语句是一种精准的迭代语句,可以用来迭代对象的属性。
mysql中leave语句的用法 说明 1、leave就是离开退出循环,好比编程里面的break一样。 2、用来从标注的流程构造中退出,通常和BEGIN … END或者循环一起使用。...set total = total + n; set n = n - 1; END LOOP ins; select total; END$ delimiter ; 以上就是mysql...中leave语句的用法,希望对大家有所帮助。...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑 收藏 | 0点赞 | 0打赏
领取专属 10元无门槛券
手把手带您无忧上云