c# – 选择具有种子的随机行
发布时间:2020-12-15 07:45:31 所属栏目:百科 来源:网络整理
导读:使用SQL Server,我有一个大约550万行的表,我想随机选择一组可能满足某些条件的120行. 这是与Select n random rows from SQL Server table和https://msdn.microsoft.com/en-us/library/cc441928.aspx相关的一些内容,但我的问题是我希望能够播种这个,所以我可
使用SQL Server,我有一个大约550万行的表,我想随机选择一组可能满足某些条件的120行.
这是与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服务器端使这项工作,所以我不必检索和处理所有行. 解决方法
如果你想要一些看似随机的东西,那么将你的[Pri??maryKey]与其他一些数据混合……
SELECT * FROM [your table] ORDER BY CHECKSUM([primarykey]) ^ CHECKSUM('your seed') …这仍然是一个表扫描,但它应该有更好的性能然后拉动整个数据集做你的客户只是抛弃除120行之外的所有东西. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- c# – Metro Style应用程序的拾色器?
- postgresql – Knex在Postgres中创建POINT数据类型
- 如何处理碰巧在Ruby中成为关键字的关键字参数?
- c – 在#define定义中获取变量值
- 简单掌握桶排序算法及C++版的代码实现
- SQlite数据库的C编程接口(五) 便捷函数(Convenience Fun
- 除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视
- postgresql – 如何在Postgres.app中降级/拥有Postgres DB的
- Postgresql
- ruby-on-rails – Rails 3如何在没有_attributes指定的情况