解决Access数据库的Sql语句中 Top n 语句获取多条记录

2019-06-22 16:06:00
tmtony8
原创
628

SQL语句在所有数据库基本是通用的,只是有部分函数命名不一致或者不存在。,

如使用ACCESS的SQL 语句 与SQL Server也大致一样,但由于Access使用的是JET SQL 而不是 真正的T-SQL语句。有时会出现一些bug。

如jet sql 会返回重复值,如果在查询TOP 语句 的后面使用Order by,而且Order by字段中有重复值的话,那么这个TOP很可能会失效, 会返回所有记录

假如共有30条记录,即使你用SELECT TOP 1 来返回记录,也同样返回30条记录,因为 JET DB 无从在这30条记录里面判断先后次序,只能返回30条。要解决此问题可以在后面加入一个主键字段


 
例如:
Select top 5 from 表名  order by FRecordDate
如果FRecordDate中有重复值,那么会显示出所有的记录来,此TOP功能会失效的
但如果FRecordDate中无重复值,那么TOP 结果正确

因此,在ACCESS中使用TOP功能要注意一下order by的字段是否会有重复值

可以采用“加入主键”的方式:

Select top 5 from 你的Access数据表名  order by FRecordDate Desc ,ID desc




分享