SQL Server 快速大数据排序方法

 SQL Server 中虽然有 ORDER BY NewID() 方法,但对于数据量比较大的结果集来说,排序那慢的可不是一星半点。

微软官方给了一种方案,https://msdn.microsoft.com/en-us/library/cc441928.aspx

示例如下:

SELECT TOP 100 * FROM [01_SubjectiveScoreInfo] WHERE (ABS(CAST((BINARY_CHECKSUM(ID, NEWID()) ) AS INT)) % 100 ) < 1

 但此方法仍我缺陷,即无法对所有记录进行排序,上例中如果总记录数小于10000,TOP 100 返回的记录数就会不足100 。

猜你喜欢

转载自www.cnblogs.com/nanfei/p/9139369.html