sqlserver随机取记录

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
3
4
5
6
7
8
9
10
11
//生成随机数
 
Random rand = new Random();
 
int num = rand.Next(MinVal,MaxVal + 1); //MinVal为主键的最小值,MaxVal为主键的最大值
 
 
 
//读取记录的Sql字符串
 
string SqlStr = "select * from tableA where PK = " + num;
sqlserver随机取记录 - 沧海 - 美丽的错误

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

方法三:

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
//将主键值读进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 tableA where PK = " + num;
sqlserver随机取记录 - 沧海 - 美丽的错误

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

posted @   Crazy Coder  阅读(27107)  评论(3编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示