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

筝筝哥哥

筝筝哥哥

2016-01-29 16:17

如何随机选取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
 
展开更多 50%)
分享

猜你喜欢

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

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

随机访问Recordset的一条记录

ASP
随机访问Recordset的一条记录

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

3.5 随机访问Recordset的一条记录

Web开发
3.5 随机访问Recordset的一条记录

MySQL随机选取数据

编程语言 网络编程
MySQL随机选取数据

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

记录集内随机取记录的代码

Web开发
记录集内随机取记录的代码

数字随机排序

编程语言 网络编程
数字随机排序

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

网卡状态不一致引起的故障

网卡状态不一致引起的故障

Photoshop教程:鼠绘一只独眼毛怪

Photoshop教程:鼠绘一只独眼毛怪
下拉加载更多内容 ↓