如何随机选取n条记录或者对记录作随机排序?
2008-04-30 15:33
183 查看
. 如何得到随机排序结果?
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
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
相关文章推荐
- 如何随机选取n条记录或者对记录作随机排序
- 记录是按照插入的顺序而返回吗,如何将返回记录随机排序
- asp+access如何随机获取N条记录?
- 设计一个算法,要求在20个数字中(0到19)随机选取十个数字,但是这十个数字不能重复(用C语言或者OC实现)
- Linq学习-关于Linq语言的如何实现随机排序的疑问
- 如何选取10——99的5个随机数,并进行从小到大排序
- 用SQL SERVER中的的一函数实现表中数据记录随机排序
- 随机从数据库中选取记录
- 随机选取算法 (有权重的记录中选取)
- 根据权重随机选取指定条数记录的简单算法实现
- 随机总数字里面选取随机数字进行随机排序案例(JAVA实现)
- 如何在数据库中获取随机的记录
- 如何用distinct消除重复记录的同时又能选取多个字段值?
- 从SQLSERVER/MYSQL数据库中随机取一条或者N条记录
- 从数据库中随机选取记录
- mysql 中对记录随机排序
- 如何得到从第M条到第N条的记录[按照某种方式排序]
- 如何在Oracle中实现SELECT TOP N,选取前几条记录
- sharepoint列表如何进行随机取几条记录?
- 如何随机的从mysql表中取出一条记录?