我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL 自定义变量@ 常用案例

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL 自定义变量@ 常用案例

MySQL 自定义变量@ 常用案例

以下文章来源于SQL开发与优化,作者郑松华

大家好,我是知数堂SQL 优化班老师 网名:骑龟的兔子

很久没有写文章,最近碰到了一个非常有意思的Oracle SQL 案例, 这个案例,我用了一些窗口函数来解决的,后来想想,能否跟MySQL 有所关联,就用一个SQL,总结了@的常用用法。

首先我们看下,如下案例

with w1 as (
     select 1    rn , "cityhp01"        mber_id     from dual union all
     select 2   , "uvis6921"     mber_id     from dual union all
     select 3   , "uvis6921"     mber_id     from dual union all
     select 4   , "moonhwa119"   mber_id    from dual union all
     select 5   , "moonhwa119"   mber_id    from dual union all
     select 6   , "b2500795"     mber_id     from dual union all
     select 7   , "b2500795"     mber_id     from dual union all
     select 8   , "b2500795"     mber_id     from dual union all
     select 9   , "dumc1234"     mber_id     from dual union all
     select 10  , "dumc1234"     mber_id     from dual
     )select * from w1;
+----+------------+
| rn | mber_id    |
+----+------------+
|  1 | cityhp01   |
|  2 | uvis6921   |
|  3 | uvis6921   |
|  4 | moonhwa119 |
|  5 | moonhwa119 |
|  6 | b2500795   |
|  7 | b2500795   |
|  8 | b2500795   |
|  9 | dumc1234   |
| 10 | dumc1234   |
+----+------------+

如上图所示,现有如下数据,在这个基础上希望得到如下结果

+----+------------+------+
| RN | MBER_ID    | S1   |
+----+------------+------+
|  1 | cityhp01   |    1 |
|  2 | uvis6921   |    2 |
|  3 | uvis6921   |    2 |
|  4 | moonhwa119 |    3 |
|  5 | moonhwa119 |    3 |
|  6 | b2500795   |    4 |
|  7 | b2500795   |    4 |
|  8 | b2500795   |    4 |
|  9 | dumc1234   |    5 |
| 10 | dumc1234   |    5 |
+----+------------+------+

一般这种情况,我们第一个想到的是dense_rank 函数

在下面的SQL 中w1 是上面的的with 语句里的w1 因为占用篇幅所以省略

 -> SELECT
    -> RN ,MBER_ID
    ->  ,DENSE_RANK() OVER(ORDER BY  MBER_ID) R
    -> FROM W1
    -> ORDER BY RN;
+----+------------+---+
| RN | MBER_ID    | R |
+----+------------+---+
|  1 | cityhp01   | 2 |
|  2 | uvis6921   | 5 |
|  3 | uvis6921   | 5 |
|  4 | moonhwa119 | 4 |
|  5 | moonhwa119 | 4 |
|  6 | b2500795   | 1 |
|  7 | b2500795   | 1 |
|  8 | b2500795   | 1 |
|  9 | dumc1234   | 3 |
| 10 | dumc1234   | 3 |
+----+------------+---+

可以看到,单纯的使用dense_rank 可以得到 相同编号,但是顺序是打乱了!

这个案例是Oracle SQL案例,如果是MySQL 就比较简单因为有@

select rn ,mber_id
    -> , @dense_rank:=@dense_rank+ case when @de=mber_id then 0 else 1 end drn
    ->  ,@de:=mber_id d1 from w1 ,(select   @dense_rank:=0 ,  @de:="" ) b
    -> ;

但是Oracle 没有自定义变量@,但是有窗口函数

我们首先分析下,MySQL 自定义写法

第一  @dense_rank:=@dense_rank+ case when @de=mber_id then 0 else 1 end drn

这段代码的意思是 如果 @de=mber_id 那么就对 @dense_rank+ 0 否则 +1 

而且累加

@de:=mber_id这个意思是把 mber_id  赋值给 @de 而刚开始 @de为‘’

所以就是 @de=mber_id 这段代码就是比较之前一行的值跟现在的比较

而Oracle 中 Lag 函数就可以求出之前一行的值

-> SELECT
    -> RN ,MBER_ID
    -> ,LAG(MBER_ID,1,"0" ) OVER(ORDER BY  RN) R
    -> FROM W1
    -> ORDER BY RN;
+----+------------+------------+
| RN | MBER_ID    | R          |
+----+------------+------------+
|  1 | cityhp01   | 0          |
|  2 | uvis6921   | cityhp01   |
|  3 | uvis6921   | uvis6921   |
|  4 | moonhwa119 | uvis6921   |
|  5 | moonhwa119 | moonhwa119 |
|  6 | b2500795   | moonhwa119 |
|  7 | b2500795   | b2500795   |
|  8 | b2500795   | b2500795   |
|  9 | dumc1234   | b2500795   |
| 10 | dumc1234   | dumc1234   |
+----+------------+------------+

然后比较mber_id 和 r 如果相同则+0 否者 +1 而且累加

, W2 AS (
    -> SELECT
    -> RN ,MBER_ID
    -> ,LAG(MBER_ID,1,"0" ) OVER(ORDER BY  RN) R
    -> FROM W1
    -> ORDER BY RN
    -> )
    -> SELECT W2.*
    -> ,SUM(
    -> CASE WHEN MBER_ID=R THEN 0 ELSE 1 END
    -> ) OVER(ORDER BY RN ) S1
    ->  FROM W2 ;

这样就可以得到我们想要的结果s1 

最后给大家提供一个包含有row_number,dense_rank的 @变量用法

以便大家当参考

select rn ,mber_id, @rn:= @rn+1 rn1
, case when @de = mber_id then @row_num := @row_num + 1
       else @row_num := 1 end nrn
, @dense_rank:=@dense_rank+ case when @de=mber_id then 0 else 1 end drn
 ,@de:=mber_id d1 from w1 ,(select @rn:=0 , @row_num:=0 , @dense_rank:=0 ,  @de:="" ) b
;

谢谢大家~ 欢迎转发。 我是知数堂SQL 优化班老师~ ^^

我的微信公众号:SQL开发与优化(sqlturning)

有问题请联系

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL 自定义变量@ 常用案例

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL 自定义变量@ 常用案例

以下文章来源于SQL开发与优化,作者郑松华大家好,我是知数堂SQL 优化班老师 网名:骑龟的兔子很久没有写文章,最近碰到了一个非常有意思的Oracle SQL 案例,这个案例,我用了一些窗口函数来解决的,后来想想,能否跟MySQL有所关联,就用一个SQL,总结
MySQL 自定义变量@ 常用案例
2019-03-05

mysql变量怎么自定义

这篇文章主要介绍“mysql变量怎么自定义”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql变量怎么自定义”文章能帮助大家解决问题。系统变量简介1、系统变量 系统变量分为全局系统变量(
2022-11-30

mysql怎么自定义常量

在MySQL中,可以使用用户变量来模拟常量的功能。用户变量的值可以在会话期间保持不变。要定义一个常量,可以使用SET语句将一个值赋给一个用户变量。例如,要定义一个名为MY_CONSTANT的常量,并将值设置为10,可以执行以下语句:SET
2023-09-25

MySQL自定义变量自增——@rownum:= @rownum+1

初识Mysql自定义变量 有时候一张表虽然设置了ID自增,但是经过一系列业务增删骚操作后自增的ID也不是那么有序,MySQL中又没有获取行号的函数,因此我们需要通过一些自定义语句来进行获取。 通常的做法是:通过定义自定义变量@ro
2023-08-16

mysql中自定义变量是什么

这篇文章给大家分享的是有关mysql中自定义变量是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、用户变量作用域:针对于当前会话(连接)有效,作用域同于会话变量声明并初始化:赋值操作符:=或:=SET @变
2023-06-15

MySQL 使用自定义变量进行查询优化

目录优化排序查询避免重复获取刚刚修改的数据行懒加载的联合查询优化排序查询自定义变量的一个重要特性是你可以同时将该变量的数学计算后的结果再赋值给该变量,类似于我们的 i = i + 1这种方式。下面是一个用于计算数据表行号的例子:SET @r
2022-05-21

MySQL 自定义变量的概念及特点

MySQL 的自定义 就是存储值的临时容器,只要与服务端的连接是活跃的,容器中的值可以保存和使用。可以通过简单的 SET 或 SELECT语句 设置自定义变量,如下所示:SET @one := 1; SET @min_actor := (S
2022-05-22

MySQL 中的用户定义变量与局部变量?

用户定义的变量也称为会话特定变量。它是一种松散类型变量,可以在会话中的某个位置进行初始化,并包含用户定义变量的值,直到会话结束。用户定义变量以符号 @ 为前缀。例如:@anyVariableName;有两种方法可以初始化用户定义的变量。您可
2023-10-22

在 MySQL 中使用用户定义的变量

让我们了解什么是用户变量以及如何在 MySQL 中使用它们。我们还将看到规则 -用户变量被写为@var_name。这里,“var_name”指的是变量名,由字母数字字符、.、_和$组成。用户变量名可以包含其他字符(如果被引号引起来)作为字符
2023-10-22

linux shell 自定义函数方法(定义、返回值、变量作用域)

一、定义shell函数(define function) 语法: [ function ] funname [()] { action; [return int;] } 说明: 1、可以带function fun() 定义,也可以直
2022-06-04

linux shell自定义函数(定义、返回值、变量作用域)介绍

一、定义shell函数(define function) 语法:[ function ] funname [()] { action; [return int;] } 说明: 1、可以带function fun() 定义,
2022-06-04

python用户自定义异常的实例讲解

说明 1、程序可以通过创建一个新的异常类来命名它们自己的异常。异常应该是典型的继承自Exception类,直接或间接的方式。 2、异常python有一个大基类,继承了Exception。因此,我们的定制类也必须继承Exception。 实例
2022-06-02

python用户自定义异常的示例分析

这篇文章主要介绍了python用户自定义异常的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。说明1、程序可以通过创建一个新的异常类来命名它们自己的异常。异常应该是典型
2023-06-20

如何在MySQL中为客户端永久定义用户定义变量?

在 MySQL 中,客户端不可能永久保存用户变量。这是因为当该客户端退出时,给定客户端连接的所有变量都会自动释放。
2023-10-22

编程热搜

目录