你的位置:首页 > 软件开发 > 数据库 > 深入MySQL用户自定义变量:使用详解及其使用场景案例

深入MySQL用户自定义变量:使用详解及其使用场景案例

发布时间:2016-10-05 18:00:11
一、前言在前段工作中,曾几次收到超级话题积分漏记的用户反馈。通过源码的阅读分析后,发现问题出在高并发分布式场景下的计数器上。计数器的值会影响用户当前行为所获得积分的大小。比如,当用户在某超级话题下连续第n(n即计数器的值)次进行转发帖子时,将会获得与n相关的分数。然而,在第一次改 ...

一、前言

在前段工作中,曾几次收到超级话题积分漏记的用户反馈。通过源码的阅读分析后,发现问题出在高并发分布式场景下的计数器上。计数器的值会影响用户当前行为所获得积分的大小。比如,当用户在某超级话题下连续第n(n即计数器的值)次进行转发帖子时,将会获得与n相关的分数。然而,在第一次改进后问题依然存在。所以,这次在之前的基础上,通过使用MySQL变量的途径来解决该问题。

二、到底MySQL的变量分哪几类?

MySQL变量一共分为两大类:用户自定义变量和系统变量。如下:

  • 用户自定义变量
    • 局部变量
    • 会话变量
  • 系统变量
    • 会话变量
    • 全局变量

本文涉及的内容为用户自定义会话变量,若对其他分类无感,请点击这里。

PS:用户定义的会话变量和系统定义的会话变量有什么区别?

局部变量

局部变量一般用于SQL的语句块中,比如存储过程中的begin和end语句块。其作用域仅限于该语句块内。生命周期也仅限于该存储过程的调用期间。

 1 drop procedure if exists add; 2 create procedure add 3 ( 4   in a int, 5   in b int 6 ) 7 begin 8   declare c int default 0; 9   set c = a + b;10   select c as c;11 end;

原标题:深入MySQL用户自定义变量:使用详解及其使用场景案例

关键词:MYSQL

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。