我使用的是MSSQL Server 2005。在我的db中,我有一个表“customerNames”,它有两列“Id”和“名称”和大约。1000年的结果。
我正在创建一个功能,每次都必须随机选择5个客户。谁能告诉我如何创建一个查询,将获得随机5行(Id,和名称)每次查询执行时?
我使用的是MSSQL Server 2005。在我的db中,我有一个表“customerNames”,它有两列“Id”和“名称”和大约。1000年的结果。
我正在创建一个功能,每次都必须随机选择5个客户。谁能告诉我如何创建一个查询,将获得随机5行(Id,和名称)每次查询执行时?
当前回答
如果你使用的是一个大表,想要访问10%的数据,那么运行下面的命令:SELECT TOP 10% * FROM Table1 ORDER BY NEWID();
其他回答
也许这个网站会有帮助。
对于那些不想点击浏览的人:
SELECT TOP 1 column FROM table
ORDER BY NEWID()
SELECT * FROM TABLENAME ORDER BY random() LIMIT 5;
SELECT TOP 5 Id, Name FROM customerNames ORDER BY NEWID()
如果有人想要PostgreSQL解决方案:
select id, name
from customer
order by random()
limit 5;
如果你不想使用NEWID()并且主键列是int,那么你可以像这样选择一个随机的主键:
with a as
(
select count(id) as row_count
from mytable
)
select *
from mytable , a
where id = round(rand() * row_count, 0)