• 流程控制结构(十)


    流程控制结构

    系统变量

    一、全局变量

    作用域:针对于所有会话(连接)有效,但不能跨重启

    查看所有全局变量
    SHOW GLOBAL VARIABLES;
    查看满足条件的部分系统变量
    SHOW GLOBAL VARIABLES LIKE '%char%';
    查看指定的系统变量的值
    SELECT @@global.autocommit;
    为某个系统变量赋值
    SET @@global.autocommit=0;
    SET GLOBAL autocommit=0;
    

    二、会话变量

    作用域:针对于当前会话(连接)有效

    查看所有会话变量
    SHOW SESSION VARIABLES;
    查看满足条件的部分会话变量
    SHOW SESSION VARIABLES LIKE '%char%';
    查看指定的会话变量的值
    SELECT @@autocommit;
    SELECT @@session.tx_isolation;
    为某个会话变量赋值
    SET @@session.tx_isolation='read-uncommitted';
    SET SESSION tx_isolation='read-committed';
    

    自定义变量

    一、用户变量

    声明并初始化:

    SET @变量名=值;
    SET @变量名:=值;
    SELECT @变量名:=值;
    

    赋值:

    方式一:一般用于赋简单的值
    SET 变量名=值;
    SET 变量名:=值;
    SELECT 变量名:=值;
    
    方式二:一般用于赋表 中的字段值
    SELECT 字段名或表达式 INTO 变量
    FROM 表;
    

    使用:

    select @变量名;
    

    二、局部变量

    声明:

    declare 变量名 类型 【default 值】;
    

    赋值:

    方式一:一般用于赋简单的值
    SET 变量名=值;
    SET 变量名:=值;
    SELECT 变量名:=值;
    
    方式二:一般用于赋表 中的字段值
    SELECT 字段名或表达式 INTO 变量
    FROM 表;
    

    使用:

    select 变量名
    

    二者的区别:

    作用域 定义位置 语法
    用户变量 当前会话 会话的任何地方 加@符号,不用指定类型
    局部变量 定义它的BEGIN END中 BEGIN END的第一句话 一般不用加@,需要指定类型

    分支

    一、if函数
    语法:if(条件,值1,值2)
    特点:可以用在任何位置

    二、case语句

    语法:

    情况一:类似于switch
    case 表达式
    when 值1 then 结果1或语句1(如果是语句,需要加分号) 
    when 值2 then 结果2或语句2(如果是语句,需要加分号)
    ...
    else 结果n或语句n(如果是语句,需要加分号)
    end 【case】(如果是放在begin end中需要加上case,如果放在select后面不需要)
    
    情况二:类似于多重if
    case 
    when 条件1 then 结果1或语句1(如果是语句,需要加分号) 
    when 条件2 then 结果2或语句2(如果是语句,需要加分号)
    ...
    else 结果n或语句n(如果是语句,需要加分号)
    end 【case】(如果是放在begin end中需要加上case,如果放在select后面不需要)
    

    特点:
    可以用在任何位置

    三、if elseif语句

    语法:

    if 情况1 then 语句1;
    elseif 情况2 then 语句2;
    ...
    else 语句n;
    end if;
    

    特点:
    只能用在begin end中!!!!!!!!!!!!!!!

    三者比较:

    应用场合
    if函数 简单双分支
    case结构 等值判断 的多分支
    if结构 区间判断 的多分支

    循环

    语法:

    【标签:】WHILE 循环条件  DO
    	循环体
    END WHILE 【标签】;
    

    特点:

    只能放在BEGIN END里面
    
    如果要搭配leave跳转语句,需要使用标签,否则可以不用标签
    
    leave类似于java中的break语句,跳出所在循环!!!
    
  • 相关阅读:
    linux-centos7-vmware 虚拟机 设置静态 ip 地址,采用 nat 模式,实现连接公网
    mysql_5.7.20 二进制包 在Linux系统中的 安装和配置
    解决windows系统80端口被占用问题
    应用系统架构演变初探
    fastdfs-nginx扩展模块源码分析
    心已落定,入驻博客园
    mac iterm 提示符序列调整
    Background removal with deep learning
    git push fatal: The remote end hung up unexpectedly
    mac sed 使用踩坑实录
  • 原文地址:https://www.cnblogs.com/akiz/p/11179096.html
Copyright © 2020-2023  润新知