微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将数据库结果筛选为查找列中每个值的前n条记录

如何解决将数据库结果筛选为查找列中每个值的前n条记录

您可以使用类似:

SELECT a.CategoryType, a.Number
FROM CategoriesAndNumbers a
WHERE a.Number IN (
    SELECT Top 3 [Number] 
    FROM CategoriesAndNumbers b 
    WHERE b.CategoryType=a.CategoryType 
    ORDER BY [Number])
ORDER BY a.CategoryType

这样做的困难在于,Jet / ACE Top选择存在重复值的地方,因此您不一定会得到三个值,如果有联系,您会得到更多的值。如果存在一个关键字段,通常可以通过一个关键字段来解决该问题:

WHERE a.Number IN (
    SELECT Top 3 [Number] 
    FROM CategoriesAndNumbers b 
    WHERE b.CategoryType=a.CategoryType 
    ORDER BY [Number], [KeyField])

但是,在这种情况下,我认为这不会有所帮助,因为外部表将包含联系。

解决方法

假设我的数据库中有两个表。

TABLE:Categories
ID|CategoryName
01|CategoryA
02|CategoryB
03|CategoryC

还有一个引用类别的表,该表还具有存储一些随机数的列。

TABLE:CategoriesAndNumbers
CategoryType|Number
   CategoryA|24
   CategoryA|22
   CategoryC|105
   .....(20,000 records)
   CategoryB|3

现在,我该如何过滤掉这些数据?因此,我想知道每个类别中最小的3个数字是什么,然后删除其余的数字。最终结果将是这样的:

TABLE:CategoriesAndNumbers
CategoryType|Number
   CategoryA|2
   CategoryA|5
   CategoryA|18
   CategoryB|3
   CategoryB|500
   CategoryB|1601
   CategoryC|1
   CategoryC|4
   CategoryC|62

现在,我可以获得所有类别中最小的数字,但是我希望每个类别都可以单独进行比较。

编辑:我正在使用Access和到目前为止这是我的代码

SELECT TOP 10 cdt1.sourceCounty,cdt1.destCounty,cdt1.distMiles
FROM countyDistanceTable as cdt1,countyTable
WHERE cdt1.sourceCounty = countyTable.countyID
ORDER BY cdt1.sourceCounty,cdt1.distMiles,cdt1.destCounty

EDIT2:感谢Remou,这将是可以解决我问题的有效查询。 谢谢!

DELETE
FROM CategoriesAndNumbers a
WHERE a.Number NOT IN (
    SELECT Top 3 [Number] 
    FROM CategoriesAndNumbers b 
    WHERE b.CategoryType=a.CategoryType 
    ORDER BY [Number])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。