http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 3937|回复: 0

[Sql Server] sqlserver随机取一条或者多条记录的方法

[复制链接]
发表于 2013-9-29 16:14:19 | 显示全部楼层 |阅读模式
                                 sqlserver随机取一条或者多条记录的方法

SqlServer本身并没有提供随机读取记录的功能,但我们可以通过一些方法来实现这个目的。本文介绍了其中几种方法并比较了各自的优劣。
方法一:
     直接通过Sql语句实现,如:
[code=sql]select top n * from tablename order by newid()[/code]

这是最简单的方法,通过调用SqlServer的newid()函数(产生GUID—全局唯一标志符)来产生随机记录。
     采用这种方法时,需要将表中所有记录与newid()生成的值进行比较从而进行排序。因此,如果表中的记录较多,操作会非常缓慢。
方法二:
     假设表中有一个自增长主键,增量为1。这时我们可以这样处理,取出主键的边界值(最大值和最小值),然后通过一个算法得到介于(包括)两个边界之间的随机值,最后按照这个值取出对应记录。下面是C#的例子:
[code=sql]//生成随机数

Random rand = new Random();

int n = rand.Next(MinVal,MaxVal + 1); //MinVal为主键的最小值,MaxVal为主键的最大值



//读取记录的Sql字符串

string SqlStr = "select * from tablename where PK = " + n;[/code]
这种方法较前一种方法的操作速度有了较大提高(特别是在大数据量的情况下)。但只有当主键值是连续的,中间没有断开的情况,并且增量为1时才能用这种方法。那么,如何才能解决这个问题呢?请继续往下看。
方法三:
     对方法二进行了改进。主要思路是,将表中所有的主键值读进一个数组,从数组中随机读出一个值,按照这个值取出对应记录。下面是C#的例子:
[code=sql]//将主键值读进ArrayList

ArrayList DataIndex = new ArrayList();

while (sdr.Read()) //sdr为存放所有主键值的SqlDataReader

{

     DataIndex.Add(sdr[0]); //存入ArrayList

}


//从ArrayList中随机读取数据项

Random rand = new Random();

int num = Convert.ToInt32(DataIndex[rand.Next(DataIndex.Length)]);


//读取记录的Sql字符串
string SqlStr = "select * from tablename where PK = " + num;[/code]
这样不管主键是否为自增长字段,也不管数值是否连续,都能够应付自如了。经过笔者的测试,在数据量为50万的情况下代码运行速度几乎没有受到什么影响,可见ArrayList的操作性能是可以信赖的。



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-11-18 05:39

© 2014-2021

快速回复 返回顶部 返回列表