目标:随即排序
反模式:
使用rand()
缺点是无法利用索引,而且是全表遍历,性能太差
合理使用反模式:
数据量很小的时候可以用
解决方案:
1、使用随机数
ceil(rand()*(select max(id) from T) as randId)
问题是,取出的id有可能是不存在的,因为id不是连续的
2、选择下一个最大值
为了避免id不存在,我们找上面那条id的后一条数据。方法是:用上面那条sql和主表再关联一次,然后找关联后的第一条
3、使用row_number
这一章也很搞啊,作者咋想的?使用rand()根本无法随机排序。
select *,RAND()as number from people --这个执行结果的每行number都是一样的(当然,每执行一次number会变一下),所以根本无法用它排序。
随机排序就用newid()就行了啊。
题外话:sqlserver的rand,一个种子只会得到唯一的结果。更杯具的是,种子连续的话,rand(seed)的结果也是有规律的!这一点很要命,以前我们用它生产一个随机码,为了避免重复,用表id做seed,结果可想而知,随机数的结果是有规律的......