SQL查询前几条记录

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL查询前几条记录相关的知识,希望对你有一定的参考价值。

各种不同的数据库查询前N条记录,都不一样,现在总结了一下,列了出来: 1. ORACLE SELECT * FROM TABLE1 WHERE ROWNUM<=N 2. INFORMIX SELECT FIRST N * FROM TABLE1 3. DB2 SELECT * ROW_NUMBER() OVER(ORDER BY COL1 DESC) AS ROWNUM WHERE ROWNUM<=N或者SELECT COLUMN FROM TABLE FETCH FIRST N ROWS ONLY 4. SQL SERVER SELECT TOP N * FROM TABLE1 5. SYBASE SET ROWCOUNT NGOSELECT * FROM TABLE1 6. mysql SELECT * FROM TABLE1 LIMIT N 7. FOXPRO SELECT * TOP N FROM TABLE ORDER BY COLUMN 8.postgres查询前几条记录SQL SELECT * FROM TABLE LIMIT 参考技术A

--可以使用 top 关键字例如:

select top 100 *  from 表名

 语句的意思就是 显示表前100条数据

参考技术B select top 5 * from table
查询前5条

SQL实现分组查询取前几条记录

我要实现的功能是统计订单日志表中每一个订单的前三条日志记录,表结构如下:

一个订单在定点杆日志表中有多条记录,要根据时间查询出每一个订单的前三条日志记录,sql如下:

 select b.OrderNumber,b.creationtime,b.remark  FROM 
 (
    SELECT a.OrderNumber,a.CreationTime,a.Remark 
    FROM [FortuneLabFord].[dbo].[SO_Log] a
    where a.SysId   IN
        (
         select TOP 3 SysId  from [FortuneLabFord].[dbo].[SO_Log] 
         where a.OrderNumber = SO_Log.OrderNumber ORDER BY a.CreationTime DESC
        )
) b  
group BY b.OrderNumber,b.creationtime,b.remark
ORDER BY b.OrderNumber 

思路是:先在内层根据CreationTime做排序,然后再自关联一下本身的表,根据主键关联,然后对结果集做分组和排序,这样就能保证同一个订单的三条记录都排在一起

这种查询方法适用于表中有唯一性标识的字段,如果没有唯一性标识的字段就不能这么查了。

以上是关于SQL查询前几条记录的主要内容,如果未能解决你的问题,请参考以下文章

SQL中显示查询结果的前几条记录

SQL中显示查询结果的前几条记录

SQL分组查询每组前几条数据

查询前几条数据

sql取出每个分组的前几条

sql查询 如何获取查找某ID的一条记录在表中是第几条记录