mysql优化查重,数据库:查重 去重

2024-03-23 10:50

本文主要是介绍mysql优化查重,数据库:查重 去重,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

4107ae7b2845

用户表全部数据如下,其中有人员的电话相同,mysql> select * from user;

+----+---------+-----------+-------------+-----+-------------------+---------+

| id | user_id | user_Name | tel        | sex | addr              | salary  |

+----+---------+-----------+-------------+-----+-------------------+---------+

|  1 | 002    | 李四      | 13222222223 | 2  | haodeffkmgmgfflfl | 3500.34 |

|  2 | 001    | 张三      | 13222222223 | 2  |                  | 5500.45 |

|  3 | 003    | 王五      | 13222222222 | 1  |                  | 4567.32 |

+----+---------+-----------+-------------+-----+-------------------+---------+

3 rows in set (0.00 sec)

1、查询场景:查询被重复注册的电话,及被注册的次数,  注意 group by 的字段必须再查询结果的字段中mysql> select tel,count(*) from user group by tel;

+-------------+----------+

| tel        | count(*) |

+-------------+----------+

| 13222222222 |        1 |

| 13222222223 |        2 |

+-------------+----------+

2 rows in set (0.01 sec)

2、查询场景:查询重复注册的手机号次数大于2 的 , 是次数的 别名mysql> select tel,count(*) regnum from user group by tel having regnum>1;

+-------------+-------+

| tel        | regnum|

+-------------+-------+

| 13222222223 |    2 |

+-------------+-------+

1 row in set (0.00 sec)

3、查询场景:查询没个手机号的注册人的所有姓名,并用,分隔。

设计函数:group_concatmysql> select tel,group_concat(user_Name) userNames from user group by tel ;

+-------------+-----------+

| tel        | userNames |

+-------------+-----------+

| 13222222222 | 王五      |

| 13222222223 | 李四,张三 |

+-------------+-----------+

2 rows in set (0.00 sec)

4、查询场景:查询用户表手机号,并去除重复

关键字:distinctmysql> select distinct tel from user;

+-------------+

| tel        |

+-------------+

| 13222222223 |

| 13222222222 |

+-------------+

2 rows in set (0.00 sec)使用关键字  group by 实现去重mysql> select tel from user group by tel;

+-------------+

| tel        |

+-------------+

| 13222222222 |

| 13222222223 |

+-------------+

2 rows in set (0.00 sec)

5、 查询场景:查询每个电话被注册最大id,及对应的电话mysql> select max(id),tel from user group by tel;

+---------+-------------+

| max(id) | tel        |

+---------+-------------+

|      3 | 13222222222 |

|      2 | 13222222223 |

+---------+-------------+

2 rows in set (0.00 sec)

6、查询场景:查询每个电话被注册最大id,

a 为第一个查询结果集的虚拟表别名mysql> select id from  (select max(id) as 'id',tel from user group by tel) a;

+------+

| id  |

+------+

|    3 |

|    2 |

+------+

2 rows in set (0.00 sec)

7、查询场景:查询每个电话的最大id的记录,mysql> select * from user where id in (select id from  (select max(id) as 'id',tel from user group by tel) a);

+----+---------+-----------+-------------+-----+------+---------+

| id | user_id | user_Name | tel        | sex | addr | salary  |

+----+---------+-----------+-------------+-----+------+---------+

|  2 | 001    | 张三      | 13222222223 | 2  |      | 5500.45 |

|  3 | 003    | 王五      | 13222222222 | 1  |      | 4567.32 |

+----+---------+-----------+-------------+-----+------+---------+

2 rows in set (0.00 sec)

8、应用场景:删除重复记录,保留没个电话的最大id的那条记录mysql> delete from user where id not in (select id from (select max(id) as 'id',tel from user group by tel)a);

Query OK, 1 row affected (0.01 sec)

mysql> select * from user;

+----+---------+-----------+-------------+-----+------+---------+

| id | user_id | user_Name | tel        | sex | addr | salary  |

+----+---------+-----------+-------------+-----+------+---------+

|  2 | 001    | 张三      | 13222222223 | 2  |      | 5500.45 |

|  3 | 003    | 王五      | 13222222222 | 1  |      | 4567.32 |

+----+---------+-----------+-------------+-----+------+---------+

2 rows in set (0.00 sec)

mysql>

这篇关于mysql优化查重,数据库:查重 去重的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_33724759/article/details/116114474
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/838093

相关文章

SQL 外键Foreign Key全解析

《SQL外键ForeignKey全解析》外键是数据库表中的一列(或一组列),用于​​建立两个表之间的关联关系​​,外键的值必须匹配另一个表的主键(PrimaryKey)或唯一约束(UniqueCo... 目录1. 什么是外键?​​ ​​​​2. 外键的语法​​​​3. 外键的约束行为​​​​4. 多列外键​

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl

PyTorch高级特性与性能优化方式

《PyTorch高级特性与性能优化方式》:本文主要介绍PyTorch高级特性与性能优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、自动化机制1.自动微分机制2.动态计算图二、性能优化1.内存管理2.GPU加速3.多GPU训练三、分布式训练1.分布式数据

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序

MySQL中like模糊查询的优化方案

《MySQL中like模糊查询的优化方案》在MySQL中,like模糊查询是一种常用的查询方式,但在某些情况下可能会导致性能问题,本文将介绍八种优化MySQL中like模糊查询的方法,需要的朋友可以参... 目录1. 避免以通配符开头的查询2. 使用全文索引(Full-text Index)3. 使用前缀索

MySQL中的两阶段提交详解(2PC)

《MySQL中的两阶段提交详解(2PC)》:本文主要介绍MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言两阶段提交过程sync_binlog配置innodb_flush_log_at_trx_commit配置总结引言在Inn

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启

MySQL中隔离级别的使用详解

《MySQL中隔离级别的使用详解》:本文主要介绍MySQL中隔离级别的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言undo log的作用MVCC的实现有以下几个重要因素如何根据这些因素判断数据值?可重复读和已提交读区别?串行化隔离级别的实现幻读和可

MySQL连接池(Pool)常用方法详解

《MySQL连接池(Pool)常用方法详解》本文详细介绍了MySQL连接池的常用方法,包括创建连接池、核心方法连接对象的方法、连接池管理方法以及事务处理,同时,还提供了最佳实践和性能提示,帮助开发者构... 目录mysql 连接池 (Pool) 常用方法详解1. 创建连接池2. 核心方法2.1 pool.q