我该怎么做呢?

select top 1 Fname from MyTbl

在Oracle 11g?


当前回答

你可以这样做

    SELECT *
      FROM (SELECT Fname FROM MyTbl ORDER BY Fname )
 WHERE rownum = 1;

您也可以使用分析函数RANK和/或DENSE_RANK,但ROWNUM可能是最简单的。

其他回答

你可以这样做

    SELECT *
      FROM (SELECT Fname FROM MyTbl ORDER BY Fname )
 WHERE rownum = 1;

您也可以使用分析函数RANK和/或DENSE_RANK,但ROWNUM可能是最简单的。

Use:

SELECT x.*
  FROM (SELECT fname 
          FROM MyTbl) x
 WHERE ROWNUM = 1

如果使用Oracle9i+,您可以使用像ROW_NUMBER()这样的分析函数,但它们的性能不如ROWNUM。

如果你只想要第一个被选中的行,你可以:

select fname from MyTbl where rownum = 1

你也可以用解析函数来排序,取最上面的x:

select max(fname) over (rank() order by some_factor) from MyTbl
SELECT *
  FROM (SELECT * FROM MyTbl ORDER BY Fname )
 WHERE ROWNUM = 1;
select * from (
    select FName from MyTbl
)
where rownum <= 1;