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 。