mysql 会话变量SET @的使用

变量要在变量名称前面加上“@”符号,叫做会话变量,代表整个会话过程他都是有作用的,这个有点类似于全局变量一样。这种变量用途比较广,因为只要在一个会话内(就是某个应用的一个连接过程中),这个变量可以在被调用的存储过程或者代码之间共享数据。

mysql declare和set定义变量除了一个不加@和一个加@这个区别之外,还有以下区别:
1、declare用来定义局部变量,在对应的begin和end之间,在end之后变量便不起作用了。
2、@用来定义会话变量。

示例:查询对于单笔订单的最大抵用金可用额度(N个抵用金同时消费)
SET @credits := 0;
select * from (
select mdl.id, mdl.credit
, (@credits := @credits+mdl.credit) credits
, expire
from MemberDepositLog mdl
where mdl.member_id = 66666
and mdl.account = 1
and mdl.status = 0
and (mdl.expire is null or mdl.expire > NOW())
and mdl.credit <= 500
order by mdl.expire ASC, mdl.credit ASC
) t1 where t1.credits <= 500

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中的会话变量和局部变量是两种不同的变量类型,它们有以下区别: 1. 作用范围不同: - 会话变量(Session Variable)是在整个数据库会话期间可见和访问的变量。它们在连接到数据库时被创建,并在断开连接时销毁。 - 局部变量(Local Variable)只在定义它们的存储过程、函数或触发器内部可见和访问。一旦存储过程、函数或触发器执行结束,局部变量将被销毁。 2. 生命周期不同: - 会话变量的生命周期与数据库会话一致,它们可以在会话期间的多个查询之间共享和保持其值。 - 局部变量的生命周期仅限于包含它们的存储过程、函数或触发器的执行过程,它们在执行结束后被销毁。 3. 默认值设置不同: - 会话变量可以通过SET语句进行赋值,并且可以在数据库会话中保持其值直到被修改或会话结束。 - 局部变量可以在声明时设置默认值,也可以通过赋值语句进行赋值。如果未显式赋值,则局部变量将为NULL。 4. 使用场景不同: - 会话变量通常用于保存用户特定的配置参数、临时计算结果等,在整个会话期间可以在多个查询中使用。 - 局部变量通常用于存储存储过程、函数或触发器内部的中间结果或临时变量,只在其所在的代码块中可见。 总的来说,会话变量适用于在整个数据库会话期间共享和保持值,而局部变量适用于在存储过程、函数或触发器内部使用的临时变量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值