如何随机选取n条记录或者对记录作随机排序?

作者:不详 来源: 日期:2002-6-14
本文适用于 SQL Server,Access 驱动没有 NEWID 函数,请参阅:如何从数据库中随机取n条记录

Q. 如何得到随机排序结果?

A. 要得到随机排序的列,或者返回x条随机选择的列,你可以使用随机数。但是RAND函数在
一个查询中只能返回一个结果。你可以在NOWID函数返回的列上做ORDER BY。请看示例:

SELECT *
FROM Northwind..Orders
ORDER BY NEWID()

SELECT TOP 10 *
FROM Northwind..Orders
ORDER BY NEWID()

这段话翻译得真是费劲,干脆不管原文,直接意译了。
不过提醒大家注意,这种方法是要对整个表扫描,然后产生一个计算列再排序的,最好不要
对大的表作这样的操作,否则会很慢的。


Q. How can I randomly sort query results?

A. To randomly order rows, or to return x number of randomly chosen rows, you
can use the RAND function inside the SELECT statement. But the RAND function is
resolved only once for the entire query, so every row will get same value. You
can use an ORDER BY clause to sort the rows by the result from the NEWID
function, as the following code shows:

SELECT *
FROM Northwind..Orders
ORDER BY NEWID()

SELECT TOP 10 *
FROM Northwind..Orders
ORDER BY NEWID()


—SQL Server MVPs
相关文章