
这是与Select n random rows from SQL Server table和https://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服务器端使这项工作,所以我不必检索和处理所有行.
解决方法 如果你想要一些看似随机的东西,那么将你的[PrimaryKey]与其他一些数据混合……SELECT *FROM [your table]ORDER BY CHECKSUM([primarykey]) ^ CHECKSUM('your seed') …这仍然是一个表扫描,但它应该有更好的性能然后拉动整个数据集做你的客户只是抛弃除120行之外的所有东西.
总结以上是内存溢出为你收集整理的c# – 选择具有种子的随机行全部内容,希望文章能够帮你解决c# – 选择具有种子的随机行所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)