一、系统变量

说明:变量由系统提供,不是用户定义,属于服务器层面
注意:如果全局级别,则需要加global,如果是会话级别,则需要加session,如果不写,则默认session
语法:

  1. 查看所有系统变量

    show global|[session] variables // show variables不写默认查会员变量
  2. 查看满足条件的部分系统变量

    show global|[session] variables like '%char%'
  3. 查看指定的某个系统变量的值

    select @@global|[session].系统变量
  4. 为某个系统变量赋值

    方式一:
    set global|[session] 系统变量名 = 值
    方式二:
    set @@global|[session].系统变量名 = 值

全局变量(global)作用域:服务器每次启动将为所有的全局变量赋初始值,针对于所有的会话(连接)有效,但不能跨重启
会话变量(session)作用域:仅仅在当前会话(连接)有效

二、自定义变量

说明:变量是用户自定义的,不是系统的
使用步骤:声明、赋值、使用(查看、比较、运算等)

  • 用户变量

作用域:针对当前会话(连接)有效,同于会话变量的作用域
赋值操作符:=或:=

  1. 声明并初始化:

    set @用户变量名=值;或
    set @用户变量名:=;或
    select @用户变量名:=值
  2. 赋值:

    方式一:
    set @用户变量名=值;或
    set @用户变量名:=;或
    select @用户变量名:=值
    方式二:
    通过select into
    select 字段 into @变量名 from 表
  3. 查看:

    select @变量名
  • 局部变量

作用域:仅仅在定义它的begin end 中有效
应用在begin end 中的第一句话

  1. 声明:

    declare 变量名 类型;
    declare 变量名 类型 default 值
  2. 赋值:

    方式一:
    通过set 或 select
    set 局部变量名=值;或
    set 局部变量名:=值;或
    select @局部变量名:=值
    方式二:
    通过select into
    select 字段 into 局部变量名 from 表;
  3. 使用:

    select 局部变量名;

binbin
37 声望3 粉丝

炎黄子孙,女娲后人,共产主义接班人