大佬教程收集整理的这篇文章主要介绍了如何在数据库表中找到重复的条目?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
嵌套查询可以完成这项工作。
SELECT author_last_name, dewey_number, Numoccurrences
FROM author INNER JOIN
( SELECT author_ID, dewey_number, COUNT(dewey_number) AS Numoccurrences
FROM book
GROUP BY author_ID, dewey_number
HAVING ( COUNT(dewey_number) > 1 ) ) AS duplicates
ON author.ID = duplicates.author_ID
(我不知道这是否是实现您想要的最快的方法。)
更新:这是我的数据
@R_801_1171@uthor;
ID | author_last_name
----+------------------
1 | Fowler
2 | knuth
3 | Lang
SELECT * FROM book;
ID | author_ID | dewey_number | title
----+-----------+--------------+------------------------
1 | 1 | 600 | Refactoring
2 | 1 | 600 | Refactoring
3 | 1 | 600 | Analysis Patterns
4 | 2 | 600 | TAOCP vol. 1
5 | 2 | 600 | TAOCP vol. 1
6 | 2 | 600 | TAOCP vol. 2
7 | 3 | 500 | Algebra
8 | 3 | 500 | Undergraduate Analysis
9 | 1 | 600 | Refactoring
10 | 2 | 500 | Concrete Mathematics
11 | 2 | 500 | Concrete Mathematics
12 | 2 | 500 | Concrete Mathematics
这是上述查询的结果:
author_last_name | dewey_number | numoccurrences
------------------+--------------+----------------
Fowler | 600 | 4
knuth | 600 | 3
knuth | 500 | 3
Lang | 500 | 2
以下查询将显示在“书”表中重复的所有杜威十进制数:
SELECT dewey_number,COUNT(dewey_number) AS Numoccurrences
FROM book
GROUP BY dewey_number
HAVING ( COUNT(dewey_number) > 1 )
但是,我想做的是让查询显示与重复条目关联的作者的姓名(“ book”表和“ author”表由“
author_id”连接)。换句话说,上面的查询将产生以下结果:
dewey_number | Numoccurrences
------------------------------
5000 | 2
9090 | 3
我希望显示的结果类似于以下内容:
author_last_name | dewey_number | Numoccurrences
-------------------------------------------------
Smith | 5000 | 2
Jones | 5000 | 2
Jackson | 9090 | 3
Johnson | 9090 | 3
jeffers | 9090 | 3
您能提供的任何帮助将不胜感激。而且,万一它起作用了,我使用的是PostgreSQL DB。
更新 :请注意,“ book”表中没有“ author_last_name”。
以上是大佬教程为你收集整理的如何在数据库表中找到重复的条目?全部内容,希望文章能够帮你解决如何在数据库表中找到重复的条目?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。