• mysql查询之 连续出现的数字,重复出现的邮箱,删除重复的电子邮箱


    1.编写一个 SQL 查询,查找所有至少连续出现三次的数字。

    +----+-----+
    | Id | Num |
    +----+-----+
    | 1  |  1  |
    | 2  |  1  |
    | 3  |  1  |
    | 4  |  2  |
    | 5  |  1  |
    | 6  |  2  |
    | 7  |  2  |
    +----+-----+
    

    例如,给定上面的 Logs 表, 1 是唯一连续出现至少三次的数字。

    +-----------------+
    | ConsecutiveNums |
    +-----------------+
    | 1               |
    +-----------------+
    select Num as ConsecutiveNums  from Logs where Id in (
        select distinct l1.Id from Logs l1,Logs l2,Logs l3
        where (l1.Num = l2.Num and l2.Num = l3.Num and ( 
             (l1.Id + 1= l2.Id  and l2.Id +1 = l3.Id)or
             (l3.Id + 1= l2.Id  and l2.Id +1 = l1.Id)or
             (l3.Id + 1= l1.Id  and l1.Id +1 = l2.Id)
          )
        ) 
    order by l1.Id)  group by Num

    2.编写一个 SQL 查询,查找 Person 表中所有重复的电子邮箱。

    示例:

    +----+---------+
    | Id | Email   |
    +----+---------+
    | 1  | a@b.com |
    | 2  | c@d.com |
    | 3  | a@b.com |
    +----+---------+
    

    根据以上输入,你的查询应返回以下结果:

    +---------+
    | Email   |
    +---------+
    | a@b.com |
    +---------+
    select Email from Person group by Email having count(Email)>1

     3.编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

    +----+------------------+
    | Id | Email            |
    +----+------------------+
    | 1  | john@example.com |
    | 2  | bob@example.com  |
    | 3  | john@example.com |
    +----+------------------+
    Id 是这个表的主键
    delete p1 from Person p1,Person p2 where p1.Email=p2.Email and p1.Id>p2.Id
  • 相关阅读:
    ABAP术语-Logical Lock
    ABAP术语-Lock Object
    ABAP术语-Lock Mode
    ABAP术语-Lock Argument
    ABAP术语-Key Field
    Python面向对象基础-day6
    Python中的内置模块与生成器迭代器-day5
    Python高阶函数与函数装饰器-day4
    Python字符编码与函数基本使用-day3
    Nginx内置变量及正则语法
  • 原文地址:https://www.cnblogs.com/baby123/p/10819357.html
Copyright © 2020-2023  润新知