加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver随机取记录

发布时间:2020-12-12 14:49:55 所属栏目:MsSql教程 来源:网络整理
导读:文章转载自:http://www.cnblogs.com/swtseaman/archive/2011/04/28/2031572.html sqlserver随机取记录 2009年03月09日 星期一 下午 06:03 SqlServer本身并没有提供随机读取记录的功能,但我们可以通过一些方法来实现这个目的。本文介绍了其中几种方法并比较

文章转载自:http://www.cnblogs.com/swtseaman/archive/2011/04/28/2031572.html

sqlserver随机取记录

2009年03月09日 星期一 下午 06:03

SqlServer本身并没有提供随机读取记录的功能,但我们可以通过一些方法来实现这个目的。本文介绍了其中几种方法并比较了各自的优劣。

方法一:

???? 直接通过Sql语句实现,如:

 
 
  1. select?top?n?*?from?tableA?order?by?newid()?

这是最简单的方法,通过调用SqlServer的newid()函数(产生GUID—全局唯一标志符)来产生随机记录。

???? 采用这种方法时,需要将表中所有记录与newid()生成的值进行比较从而进行排序。因此,如果表中的记录较多,操作会非常缓慢。

方法二:

???? 假设表中有一个自增长主键,增量为1。这时我们可以这样处理,取出主键的边界值(最大值和最小值),然后通过一个算法得到介于(包括)两个边界之间的随机值,最后按照这个值取出对应记录。下面是C#的例子:

 
 
  1. //生成随机数?
  2. Random?rand?=?new?Random();?
  3. int?num?=?rand.Next(MinVal,MaxVal?+?1);?//MinVal为主键的最小值,MaxVal为主键的最大值?
  4. ??
  5. //读取记录的Sql字符串?
  6. string?SqlStr?=?"select?*?from?tableA?where?PK?=?"?+?num;?

这种方法较前一种方法的操作速度有了较大提高(特别是在大数据量的情况下)。但只有当主键值是连续的,中间没有断开的情况,并且增量为1时才能用这种方法。那么,如何才能解决这个问题呢?请继续往下看。

方法三:

???? 对方法二进行了改进。主要思路是,将表中所有的主键值读进一个数组,从数组中随机读出一个值,按照这个值取出对应记录。下面是C#的例子:

 
 
  1. //将主键值读进ArrayList?
  2. ArrayList?DataIndex?=?new?ArrayList();?
  3. while?(sdr.Read())?//sdr为存放所有主键值的SqlDataReader?
  4. {?
  5. ?????DataIndex.Add(sdr[0]);?//存入ArrayList?
  6. }?
  7. ??
  8. //从ArrayList中随机读取数据项?
  9. Random?rand?=?new?Random();?
  10. int?num?=?Convert.ToInt32(DataIndex[rand.Next(DataIndex.Length)]);?
  11. ??
  12. //读取记录的Sql字符串?
  13. string?SqlStr?=?"select?*?from?tableA?where?PK?=?"?+?num;?

这样不管主键是否为自增长字段,也不管数值是否连续,都能够应付自如了。经过笔者的测试,在数据量为50万的情况下代码运行速度几乎没有受到什么影响,可见ArrayList的操作性能是可以信赖的。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读