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

MySQL中怎么查询多条不重复记录值

短信预约 -IT技能 免费直播动态提醒
省份

北京

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

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

看不清楚,换张图片

免费获取短信验证码

MySQL中怎么查询多条不重复记录值

今天就跟大家聊聊有关MySQL中怎么查询多条不重复记录值,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

table

id name

1 a

2 b

3 c

4 c

5 b


库结构大概这样,这只是一个简单的例子,实际情况会复杂得多。


比如我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。


select distinct name from table

得到的结果是:


name

a

b

c


好像达到效果了,可是,我想要得到的是id值呢?改一下查询语句吧:


select distinct name, id from table


结果会是:


id name

1 a

2 b

3 c

4 c

5 b


distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除……


我们再改改查询语句:


select id, distinct name from table


很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把distinct放到where条件里?能,照样报错。。。。。。。


很麻烦吧?确实,费尽心思都没能解决这个问题。没办法,继续找人问。


拉住公司里一JAVA程序员,他给我演示了oracle里使用distinct之后,也没找到mysql里的解决方案,最后下班之前他建议我试试group by。


试了半天,也不行,最后在mysql手册里找到一个用法,用group_concat(distinct name)配合group by name实现了我所需要的功能,兴奋,天佑我也,赶快试试。


报错。。。。。。。。。。。。郁闷。。。。。。。连mysql手册也跟我过不去,先给了我希望,然后又把我推向失望,好狠哪。。。。


再仔细一查,group_concat函数是4.1支持,晕,我4.0的。没办法,升级,升完级一试,成功。。。。。。


终于搞定了,不过这样一来,又必须要求客户也升级了。


突然灵机一闪,既然可以使用group_concat函数,那其它函数能行吗?


赶紧用count函数一试,成功,我。。。。。。。想哭啊,费了这么多工夫。。。。。。。。原来就这么简单……


现在将完整语句放出:


select *, count(distinct name) from table group by name


结果:


id name count(distinct name)

1 a 1

2 b 1

3 c 1


最后一项是多余的,不用管就行了,目的达到。


唉,原来mysql这么笨,轻轻一下就把他骗过去了,郁闷也就我吧(对了,还有容容那家伙),现在拿出来希望大家不要被这问题折腾。


哦,对,再顺便说一句,group by 必须放在 order by 和 limit之前,不然会报错.

更郁闷的事情发生了,在准备提交时容容发现,有更简单的解决方法:


select id, name from table group by name

看完上述内容,你们对MySQL中怎么查询多条不重复记录值有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

免责声明:

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

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

MySQL中怎么查询多条不重复记录值

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

下载Word文档

猜你喜欢

MySQL重复记录怎么查询

可以使用GROUP BY和HAVING子句来查询MySQL中的重复记录。假设有一张名为table1的表,其中包含一个名为column1的字段。要查询重复记录,可以使用以下查询语句:SELECT column1, COUNT(*) as
MySQL重复记录怎么查询
2024-04-09

MySQL中怎么查找重复的记录

要查找MySQL中重复的记录,可以使用以下SQL查询语句:SELECT column1, column2, COUNT(*)FROM table_nameGROUP BY column1, column2HAVING COUNT(*
MySQL中怎么查找重复的记录
2024-04-09

PHP中怎么查询前十条记录

这篇文章主要讲解了“PHP中怎么查询前十条记录”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP中怎么查询前十条记录”吧!连接到数据库首先,我们需要使用PHP代码连接到数据库。在这里,我们
2023-07-06

MySQL中怎么查询不重复的数据

这篇文章主要介绍了MySQL中怎么查询不重复的数据的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySQL中怎么查询不重复的数据文章都会有所收获,下面我们一起来看看吧。一、查询不重
2023-04-28

MySQL中查询、删除重复记录的方法大全

前言本文主要给大家介绍了关于MySQL中查询、删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍:查找所有重复标题的记录:1select title,count(*) as count from user_table group by title
2018-05-22

MySQL中查询、删除重复记录的方法大全

前言本文主要给大家介绍了关于MySQL中查询、删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍:查找所有重复
2022-08-10

SQLServer中怎么查找重复记录

在SQLServer中查找重复记录可以使用以下方法:方法一:使用COUNT()函数和GROUP BY子句查找重复记录SELECT column1, column2, COUNT(*)FROM table_nameGROUP BY c
SQLServer中怎么查找重复记录
2024-03-11

sql怎么查询重复数据并显示记录

可以使用SELECT语句结合GROUP BY和HAVING子句来查询重复数据并显示记录。以下是一个示例:假设有一个名为"customers"的表,包含以下字段:id (主键)nameemail要查询重复的电子邮件地址并显示记录,可以使用以下
2023-09-15

编程热搜

目录