MySQL - 变量

系统变量

由MySQL数据库系统提供的变量,无需用户定义。根据作用域的不同,系统变量可分为全局变量和会话变量。

  • 全局变量
    针对整个服务器,即所有的连接都起作用,若服务器重启则会恢复原始,之前所做的更改都会无效。
  • 会话变量
    针对当前连接,不影响其它的连接。

系统变量的相关操作

不指定变量的作用范围时,默认是会话级别的。

  • 使用匹配方式查看系统变量
    SHOW [GLOBAL|SESSION]  VARIABLES [LIKE <变量匹配表达式>];
    
  • 查看指定的某个系统变量
    SELECT @@[GLOBAL|SESSION.]<变量名>;
    
  • 修改变量
    #方式1:
    SET @@[GLOBAL|SESSION.]<变量名> = <>;
    #方式2:
    SET [GLOBAL|SESSION.] <变量名> = <>;
    

自定义变量

自定义变量是由用户自己定义的变量,可分为用户变量和局部变量。

  • 用户变量
    作用域是当前会话。
    • 变量的声明和初始化
      SET @<变量名> = <>;
      
    • 变量的赋值或者修改
      #方式1:
      SET @<变量名> = <>;
      #方式2:
      SET @<变量名> := <>;
      #方式3:
      SELECT <字段,表达式> INTO @<变量名> [FROM <>];
      
  • 局部变量
    作用域在BEGIN END块中。
    • 变量的声明和初始化
      变量的声明语句必须放在BEGIN END的最前面,即声明语句之前不能有其他语句。
      DECLARE <变量名> <变量类型> [default <默认值>];
      
    • 变量的赋值或者修改
      #方式1:
      SET <变量名> = <>;
      #方式2:
      SET <变量名> := <>;
      #方式3:
      SELECT <字段,表达式> INTO <变量名> [FROM <>];
      
      局部变量的操作和用户变量的操作的差异就在于在变量名的前面少使用一个@符号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值