当前位置:  开发笔记 > 编程语言 > 正文

选择带有种子的随机行

如何解决《选择带有种子的随机行》经验,为你挑选了0个好方法。

使用SQL Server,我有一个大约550万行的表,我想随机选择一组可能满足某些条件的120行.

这是与SQL Server表和https://msdn.microsoft.com/en-us/library/cc441928.aspx中选择n个随机行相关的一些内容,但我的问题是我希望能够播种这个以便我可以随机选择相同的 120行,然后如果我使用不同的种子,则获得一组不同的随机行.

可以在我的应用程序中执行以下操作:

var rand = new Random(seed);
var allExamples = db.myTable.Where(/*some condition*/).ToList();
var subSet = db.myTable.Select(x => new { x, r = rand.NextDouble())
    .OrderBy(x => x.r)
    .Take(120)
    .Select(x => x.x).ToList();

哪个有效,但是,正如你可能猜到的那样,550万行是冰冷的.所以我真的在寻找一种方法在SQL服务器端使这项工作,所以我不必检索和处理所有行.

推荐阅读
依然-狠幸福
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有