MySQL 自定义变量@ 常用案例「终于解决」

MySQL 自定义变量@ 常用案例「终于解决」以下文章来源于SQL开发与优化,作者郑松华 大家好,我是知数堂SQL 优化班老师 网名:骑龟的兔子 很久没有写文章,最近碰到了一个非常有意思的Oracle SQL 案例, 这个案例,我用了一些窗口函…

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   |
+----+------------+

代码100分

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

代码100分+----+------------+------+
| 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 就比较简单因为有@

代码100分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
    -> ;

MySQL 自定义变量@ 常用案例「终于解决」

但是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 ;

MySQL 自定义变量@ 常用案例「终于解决」

这样就可以得到我们想要的结果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
;

MySQL 自定义变量@ 常用案例「终于解决」

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

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

有问题请联系 MySQL 自定义变量@ 常用案例「终于解决」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/9399.html

(0)
上一篇 2023-02-09
下一篇 2023-02-09

相关推荐

  • Python数据类型:变量、数据类型及其应用

    Python数据类型:变量、数据类型及其应用a href=”https://www.python100.com/a/sm.html”font color=”red”免责声明/font/a a href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2023-12-20
    114
  • Python计算时间差

    Python计算时间差在Python编程中,我们通常需要计算时间差。时间差就是在两个时间点之间相隔的时间。比如我们想要知道两个事件发生的时间差,或者我们需要计算程序运行的时间等等,这时就需要用到Python的时间模块。

    2024-04-24
    49
  • postgresql中时间转换TO_DATE和TO_TIMESTAMP

    postgresql中时间转换TO_DATE和TO_TIMESTAMP起因:使用TO_DATE转换时分秒的数据时,将当天的数据过滤掉了,实际并没有统计到当天数据,发现TO_DATE转换的时候,不带有时分秒,这个跟oracle差异较大。 解决办法 1.使用TO_TIME…

    2023-03-17
    156
  • Python实现矩阵乘法

    Python实现矩阵乘法矩阵乘法是线性代数中的重要概念,对于Python工程师来说,熟练掌握矩阵乘法的方法是非常有必要的。Python在实现矩阵乘法时,可以通过NumPy库中的dot函数来进行计算。该函数可以接受2个ndarray型的参数,返回它们的矩阵乘积。

    2024-06-24
    48
  • Mysql中的范式

    Mysql中的范式目录 范式定义 第一范式 第二范式 第三范式 反范式 范式定义 范式:Normal Format,是一种离散数学中的知识,是为了解决数据的存储与优化的问题:保存数据的存储之后,凡是能够通过关系寻找出来

    2023-02-08
    148
  • shiro如何实现认证和授权_shiro认证

    shiro如何实现认证和授权_shiro认证Shiro默认使用自带的IniRealm,IniRealm从ini配置文件中读取用户的信息,大部分情况下需要从系统的数据库中读取用户信息,所以需要自定义realm。 1,Realm接口 最基础的是R…

    2023-04-05
    148
  • HBase/TiDB都在用的数据结构:LSM Tree,不得了解一下?[通俗易懂]

    HBase/TiDB都在用的数据结构:LSM Tree,不得了解一下?[通俗易懂]LSMTree(Log-structuredmerge-tree)广泛应用在HBase,TiDB等诸多数据库和存储引擎上,我们先来看一下它的一些应用:这么牛X的名单,你不想了解下LSMTree吗?装…

    2023-04-04
    143
  • 使用Jupyter自动补全优化编程效率

    使用Jupyter自动补全优化编程效率Jupyter是一个非常流行的交互式计算环境,特别适合用于数据科学和科学计算。Jupyter环境可以在浏览器中运行,并提供了非常方便的编程和数据分析能力。Jupyter自动补全是其中一个非常重要的功能,可以帮助我们快速编写代码并提高编码效率。

    2024-08-27
    23

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注