我使用的是MSSQL Server 2005。在我的db中,我有一个表“customerNames”,它有两列“Id”和“名称”和大约。1000年的结果。
我正在创建一个功能,每次都必须随机选择5个客户。谁能告诉我如何创建一个查询,将获得随机5行(Id,和名称)每次查询执行时?
我使用的是MSSQL Server 2005。在我的db中,我有一个表“customerNames”,它有两列“Id”和“名称”和大约。1000年的结果。
我正在创建一个功能,每次都必须随机选择5个客户。谁能告诉我如何创建一个查询,将获得随机5行(Id,和名称)每次查询执行时?
当前回答
如果你使用Yandex数据库,那么你应该使用
select column from table order by random (TableRow()) limit 1;
其他回答
如果你有一个有数百万行的表,并且关心性能,这可能是一个更好的答案:
SELECT * FROM Table1
WHERE (ABS(CAST(
(BINARY_CHECKSUM
(keycol1, NEWID())) as int))
% 100) < 10
https://msdn.microsoft.com/en-us/library/cc441928.aspx
我发现这对大数据最有效。
SELECT TOP 1 Column_Name FROM dbo.Table TABLESAMPLE(1 PERCENT);
TABLESAMPLE(n ROWS)或TABLESAMPLE(n PERCENT)是随机的,但需要添加TOP n以获得正确的样本量。
在大型表上使用newwid()非常慢。
如果有人想要PostgreSQL解决方案:
select id, name
from customer
order by random()
limit 5;
SELECT TOP 5 Id, Name FROM customerNames ORDER BY NEWID()
也许这个网站会有帮助。
对于那些不想点击浏览的人:
SELECT TOP 1 column FROM table
ORDER BY NEWID()