1. 概述
当多表连接查询多个字段出现重复数据时,我们由于业务需要,大部分时候只需要其中的一条就行了,所以数据去重就格外重要。
2. 简单问题例子
- .通过jion 查询出数据
select user.userName,teacher.sex, user.`password` from user JOIN teacher on user.id = teacher.id
结果

目标: 发现userName,password中张三和admin重复了,假设我们只需要其中一条数据,而不去分辨男女
3. 解决方法
3.1使用group by
- sql代码
select user.userName,teacher.sex, user.`password` from user JOIN teacher on user.id = teacher.id group by user.userName,
user.`password`
- 结果

但是有时我们进行了group by 会改变原理的排序,并且不能与order by使用,这是另外的一个函数。
3.2 row_number () over
- sql代码
select * from
(SELECT
userName,
sex,
PASSWORD,
USER.id,
row_number ( ) over ( PARTITION BY userName,PASSWORD ORDER BY USER.id ) as user_rn
FROM
USER JOIN teacher ON USER.id = teacher.id)
where user_rn = 1
但是如果如果排序的字段不是数字需要进行转化
to_number()
这种做法也是通过分组排序后面进行升序或者降序取第一个行数据,但是如果单列也可以只用distinct,详情可以见
distinct使用
版权声明:本文为qq_38212913原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。