ANSI SQL version of SELECT TOP 1

后端 未结 2 1825
南笙
南笙 2020-12-17 16:01

Is there an ANSI SQL compliant version of SQL SERVER\'s SELECT TOP n?

相关标签:
2条回答
  • 2020-12-17 16:29

    ANSI/ISO SQL:2003 introduced windowing functions:

    SELECT * FROM (
      SELECT
        ROW_NUMBER() OVER (ORDER BY age ASC) AS rownum,
        person_id,
        person_name,
        age
      FROM person
    ) AS foo
    WHERE rownum <= 3
    

    Microsoft SQL Server has supported this syntax since SQL Server 2005. http://msdn.microsoft.com/en-us/library/ms189798(v=sql.90).aspx

    ANSI/ISO SQL:2008 introduced a simpler syntax for FETCH FIRST, which may be more analogous to Microsoft/Sybase TOP syntax:

    SELECT person_id, person_name, age FROM person
    FETCH FIRST 3 ROWS ONLY
    

    Microsoft does not yet support this syntax. See also http://en.wikipedia.org/wiki/Select_(SQL)#Limiting_result_rows

    If you're still using Microsoft SQL Server 2000, you should read a question I posted a while back about doing "paging" style queries: Emulate MySQL LIMIT clause in Microsoft SQL Server 2000

    0 讨论(0)
  • 2020-12-17 16:30

    'LIMIT' works with Amazon's Athena:

    SELECT * FROM myTable LIMIT 3;
    
    0 讨论(0)
提交回复
热议问题