MySql(二十四)变量之自定义变量


变量概括图如下:
在这里插入图片描述

自定义变量

自定义变量:分为局部变量和用户变量

定义:见名知意即是用户自定义的变量

注:有自定义变量是由用户自定的变量,因此在使用之前需要用用户声明赋值才可以使用。

使用步骤:声明—>赋值 —> 使用(查看、比较、运算等)

局部变量

作用域:仅仅在它定义的begin end中有效

(应用在begin end 中且必须放在begin end中的第一句话)

使用步骤:

① 声明

Declare 变量名 类型; 或者

Declare 变量名 类型 default 值;

②赋值(更新用户变量的值)

方法一:通过set或select

Set 局部变量名= 值; 或

set 局部变量名:=值; 或

select @局部变量名:=值;

方法二:通过select into

Select 字段 into 局部变量名 From 表;

② 使用

Select 局部变量名;

用户变量

作用域:针对于当前会话(连接)有效,同于会话变量的作用域

(用户变量可以应用在任意地方:begin end里面或者begin end外面都可以)

① 声明并初始化

方法一:Set @用户变量名= 值;

方法二:set @用户变量名:=值;

方法三:select @用户变量名:=值;

② 赋值(更新用户变量的值)

方法一:通过set或select

Set @用户变量名= 值; 或

set @用户变量名:=值; 或

select @用户变量名:=值;

案例:

Set @name = ‘join’;

Set @name 100;

方法二:通过select into

Select 字段 into 变量名

​ From 表;

(这里是查询表中的一个字段值并赋值给变量)

案例:

Set @number = 1;

Select count(*) into @number from students;

③ 使用(查看用户变量的值)

Select @用户变量名;

案例:select @number;

用户变量和局部变量的区别

作用域定义和使用的位置语法
用户变量当前会话会话当中的任何地方必须加@;不需要限定类型
局部变量Begin end中Begin end中一般不需要加@;需要限定类型

综合案例:声明两个变量并赋初始值,求和并打印

  1. 用户变量

    Set @num1 = 1;
    Set @num2 = 2;
    Set @sum = @num1 + @num2;
    Select @sum;
    
  2. 局部变量

    begin
    Declare num1 int default 1;
    Declare num2 int default 2;
    Declare sum int;
    Set sum = num1 + num2;
    Select sum;
    End
    

    总结: 自定义变量之局部变量和用户变量的比较:

自定义变量的使用步骤:声明—>赋值 —> 使用(查看、比较、运算等)

自定义变量声明赋值使用
局部变量Declare 变量名 类型 【default 值;】set 变量名 = 值; 或者 set 变量名 := 值 ;或者select @变量名:=值; 或者 Select 字段 into 变量名 From 表;Select 变量名;
用户变量set 变量名 = 值; 或者 set 变量名 := 值 ;或者select @变量名:=值;set 变量名 = 值; 或者 set 变量名 := 值 ;或者select @变量名:=值; 或者 Select 字段 into 变量名 From 表;Select @变量名;select 变量名;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值