我爱Aspx >> 数据库 >> 如何随机选取n条记录或者对记录作随机排序如何随机选取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
【我对这篇文章有话说?】
如何将作为字符串保存的IP地址变..[05-22]
如何区分大小写比较[05-22]
如何在视图中使用ORDER BY短语[05-22]
TOP N 和SET ROWCOUNT N 哪个更快[05-22]
关于DTS导入导出丢失默认值等对象[05-22]
正确配置和使用SQL mail[05-22]
用sql语句修改数据表中字段 实现..[05-22]
分布式查询和分布式事务[05-22]
在存储过程中使用use database[05-22]
不能作为“sysadmin”登录SQL Se..[05-22]