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版激活秘钥/序列号/激活码推荐 附激活工具 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具阅读:74 
-   如何安装mysql8.0 如何安装mysql8.0阅读:31 
-   Word快速设置标题样式步骤详解 Word快速设置标题样式步骤详解阅读:28 
-   20+道必知必会的Vue面试题(附答案解析) 20+道必知必会的Vue面试题(附答案解析)阅读:37 
-   HTML如何制作表单 HTML如何制作表单阅读:22 
-   百词斩可以改天数吗?当然可以,4个步骤轻松修改天数! 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!阅读:31 
-   ET文件格式和XLS格式文件之间如何转化? ET文件格式和XLS格式文件之间如何转化?阅读:24 
-   react和vue的区别及优缺点是什么 react和vue的区别及优缺点是什么阅读:121 
-   支付宝人脸识别如何关闭? 支付宝人脸识别如何关闭?阅读:21 
-   腾讯微云怎么修改照片或视频备份路径? 腾讯微云怎么修改照片或视频备份路径?阅读:28 















