Foxtable(狐表)用户栏目专家坐堂 → 高效随机抽取少量和大量记录的方法


  共有4326人关注过本帖树形打印复制链接

主题:高效随机抽取少量和大量记录的方法

帅哥哟,离线,有人找我吗?
有点酸
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1093 积分:6682 威望:0 精华:0 注册:2013/7/1 9:05:00
  发帖心情 Post By:2015/5/14 23:10:00 [显示全部帖子]

5楼洗牌的方法是错误的,会导致靠前的记录被抽取的概率大,下面这样,前后的机会才均等:

 

Dim cnt As Integer = DataTables("订单").DataRows.Count
Dim ids(cnt - 1) As Integer
Dim rnd(cnt -1) As Integer
For i As Integer = 0 To cnt -1
    ids(i) = i
    rnd(i) = rand.Next(0,cnt)
Next
array.sort(rnd,ids)
Tables("订单").StopRedraw()
DataTables("订单").ReplaceFor("选择",False)
For i As Integer =  1 To 100 '100为要抽取的行数
    DataTables("订单").DataRows(ids(i-1))("选择") = True
Next
Tables("订单").Filter = "[选择] = True"
Tables("订单").ResumeRedraw()

 

但是Array.Sort帮助没有介绍,下面的代码完全采用帮助的知识,性能基本一致:

 

Dim cnt As Integer = DataTables("订单").DataRows.Count
Dim ids As New List(of Integer)
For i As Integer = 0 To cnt -1
    ids.add(i)
Next
Do
    Dim n As Integer = rand.Next(0,ids.count)
    ids.RemoveAt(n)
Loop While ids.count > 100  '100为要随机抽取的行数
Tables("订单").StopRedraw()
DataTables("订单").ReplaceFor("选择",False)
For Each i As Integer In ids
    DataTables("订单").DataRows(i)("选择") = True
Next
Tables("订单").Filter = "[选择] = True"
Tables("订单").ResumeRedraw()

 

[此贴子已经被作者于2015/5/14 23:14:15编辑过]

 回到顶部