AI 概述
1. 单字段去重2. 多字段去重3. 小结 前面小节介绍了如何使用 GROUP BY 对查询数据分组,并且 GROUP BY 能起到有效去重作用,本小节介绍如何使用 DISTINCT 去重。 1. 单字段去重 以表 student_course 和 表 student 链接为例: SELECT * FROM student_course a INNER JOIN student b ON a.student_id=b....
目录
文章目录隐藏
  1. 1. 单字段去重
  2. 2. 多字段去重
  3. 3. 小结

前面小节介绍了如何使用 GROUP BY 对查询数据分组,并且 GROUP BY 能起到有效去重作用,本小节介绍如何使用 DISTINCT 去重。

1. 单字段去重

以表 student_course 和 表 student 链接为例:

SELECT * FROM student_course a INNER JOIN student b ON a.student_id=b.id;

查询结果如下图:

DISTINCT 去重

上图查询结果中,若只需要学生信息,则需要对结果进行去重:

SELECT DISTINCT student_id 
FROM 
student_course a 
INNER JOIN 
student b 
ON a.student_id=b.id;

执行结果如下图 :

DISTINCT 去重

2. 多字段去重

以表 student_course、course、course、teacher 链接为例:

SELECT * 
FROM 
student_course a 
INNER JOIN 
course b 
ON a.course_id=b.id 
INNER JOIN teacher c 
ON b.teacher_id=c.id;

查询结果如下图:

多字段去重

如上图,若需要得到所有教师的所有课程信息,则需要多个字段对结果去重:

SELECT 
DISTINCT  a.course_id,b.course_name,b.teacher_id,c.name
FROM 
student_course a 
INNER JOIN 
course b 
ON a.course_id=b.id 
INNER JOIN teacher c 
ON b.teacher_id=c.id;

去重后查询结果如下图 :

去重后查询

多字段去重意思就是只有所有指定的列信息都相同,才会被认定为重复的信息。

3. 小结

本小节介绍了如何使用 DISTINCT 去重,之前介绍的 GROUP BY 也能起到去重的作用,使用的频率相对较高,它的目的是用来分组进行聚合统计的,例如需要对分组的数据统计:

SELECT teacher_id,count(*) FROM course GROUP BY teacher_id;

执行结果如下图:

DISTINCT 去重

如上图所示,count(*) 表示使用聚合函数对分组数据统计,这里可以理解为分组重复的总数,例如 teacher_id=1 的总共有 5 条。

以上关于26. DISTINCT 去重的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » 26. DISTINCT 去重

发表回复