SQL反模式笔记15——随机排序

目标:随即排序

反模式:

  使用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,结果可想而知,随机数的结果是有规律的......

转载于:https://www.cnblogs.com/anyenajie/archive/2012/05/08/2489486.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值