c# – 选择具有种子的随机行

前端之家收集整理的这篇文章主要介绍了c# – 选择具有种子的随机行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
使用sql Server,我有一个大约550万行的表,我想随机选择一组可能满足某些条件的120行.

这是与Select n random rows from SQL Server tablehttps://msdn.microsoft.com/en-us/library/cc441928.aspx相关的一些内容,但我的问题是我希望能够播种这个,所以我可以随机选择相同的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服务器端使这项工作,所以我不必检索和处理所有行.

解决方法

如果你想要一些看似随机的东西,那么将你的[Pri​​maryKey]与其他一些数据混合……
SELECT *
FROM [your table]
ORDER BY
    CHECKSUM([primarykey]) ^ CHECKSUM('your seed')

…这仍然是一个表扫描,但它应该有更好的性能然后拉动整个数据集做你的客户只是抛弃除120行之外的所有东西.

猜你在找的C#相关文章