sql2000,返回随机记录
时间:2011-12-06
来源:互联网
在SQL2000中,假设有表t,t有2个字段:ID(标识列),Name,表中有100条记录
问:如何通过查询语句随机返回5条记录,也就说要得到记录中5个不重复的Name
说明:只讨论用sql,因为这只是问题的简化版,不要讨论数组。另外,如果需要也可以增加辅助列。当然如果是通过全表更新随机数据再排序返回也不是我需要的。
麻烦大家了。
问:如何通过查询语句随机返回5条记录,也就说要得到记录中5个不重复的Name
说明:只讨论用sql,因为这只是问题的简化版,不要讨论数组。另外,如果需要也可以增加辅助列。当然如果是通过全表更新随机数据再排序返回也不是我需要的。
麻烦大家了。
作者: crxwz 发布时间: 2011-12-06
SQL code
SELECT TOP 5 * FROM T ORDER BY NEWID()
作者: Haiwer 发布时间: 2011-12-06
SQL code
select top 5 * from t as a where not exists(select 1 from t where Name=a.Name and ID<a.ID) order by newID() 或 select top 5 min(ID) as ID,Name from t group by Name order by newID()
作者: roy_88 发布时间: 2011-12-06
忘记说明一点表中Name不重复。
这个查询要频繁调用,请问newID()是在服务端还是客户端执行。
这个查询要频繁调用,请问newID()是在服务端还是客户端执行。
作者: crxwz 发布时间: 2011-12-06
服务端
引用 3 楼 crxwz 的回复:
忘记说明一点表中Name不重复。
这个查询要频繁调用,请问newID()是在服务端还是客户端执行。
忘记说明一点表中Name不重复。
这个查询要频繁调用,请问newID()是在服务端还是客户端执行。
作者: geniuswjt 发布时间: 2011-12-06
随机取记录
大版写的SQL可能会出现相同Name的最大那一行永远也取不到吧
大版写的SQL可能会出现相同Name的最大那一行永远也取不到吧
作者: pengxuan 发布时间: 2011-12-06
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28