欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > 数据库 >内容正文

数据库

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

发布时间:2024/1/23 数据库 48 豆豆
生活随笔 收集整理的这篇文章主要介绍了 mysql 统计 邮箱_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 fromLogs l1,Logs l2,Logs l3where (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

总结

以上是生活随笔为你收集整理的mysql 统计 邮箱_mysql查询之 连续出现的数字,重复出现的邮箱,删除重复的电子邮箱...的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。