百独托管7500[泰海10年]服务器16核32G内存300元CPC单价3毛/CPV万IP展示160元无视cc/ddos【无敌超级防御服务器】
提升alexa排名、提升IP流量 7Q5团队国外域名/主机即开即用腾讯云,热门云产品3折起【好耶数据】高防服务器,随时退换
小飞国外网赚,手把手带你月入万元炎黄网络4H4G10M99元每月美国/香港站群优惠活动中客科技OAO数据中心-服务器租用
出售中易广告联盟系统,移动广告平台企业福利专场,腾讯云服务器2.5折起九九数据 - 工信部正规资质接入商腾讯云新用户专属大礼包,海量代金券
【9.9元起】20国云服务器招商送OEM301国内免备案服务器招代理租服务器就找【45互联】随时退换阿里云轻量应用服务器,低至350元/年

[落伍原创] Mysql随机获得一条或多条记录 [复制链接]
查看:5517 | 回复:2

11

主题

1万

帖子

2625

积分

保护或锁定(状态异常,请联系客服)

WEB标准化志愿者

贡献
5535
鲜花
4
注册时间
2006-12-13
发表于 2011-3-31 11:20:22 | |阅读模式
赚钱宝三代推广大使招募           
研究一些随机的因素,主要是讲究效率问题。

语句一:
  1. select * from users order by rand() LIMIT 1
复制代码
MYSQL手册里面针对RAND()的提示大概意思就是,在 ORDER BY从句里面不能使用RAND()函数,因为这样会导致数据列被多次扫描,导致效率相当相当的低,效率不行,切忌使用。

---------分隔线------------------------------------

语句二:
  1. SELECT * FROM users  AS t1  JOIN (SELECT ROUND(RAND() * ((SELECT MAX(userId) FROM `users`)-(SELECT MIN(userId) FROM users))+(SELECT MIN(userId) FROM users)) AS userId) AS t2 WHERE t1.userId >= t2.userId ORDER BY t1.userId LIMIT 1
复制代码
执行该sql语句,用时0.031s,效率非常好。当把”LIMIT 1“改为了”LIMIT 100“ 随机取一百条记录,用时0.048s。可是就在此时问题出现了,发现结果好像不是随机的。为了验证结果,又执行了N次,的确不是随机的。问题出现在”ORDER BY t1.userId“这里,按userId排序了。随机取一条记录还是不错的选择,多条就不行了啊。

---------分隔线------------------------------------

语句三:
  1. SELECT * FROM users WHERE userId >= ((SELECT MAX(userId) FROM users)-(SELECT MIN(userId) FROM users)) * RAND() + (SELECT MIN(userId) FROM users)  LIMIT 1
复制代码
执行该sql语句,用时0.039s,效率也是非常好。接着把”LIMIT 1“改为了”LIMIT 10000“,用时0.063s。经过多次验证,得出的结果都是随机的。

---------分隔线------------------------------------

结论:语句一效率不行,切忌使用。随机获得一条记录,语句二是相当不错的选择,采用JOIN的语法比直接在WHERE中使用函数效率还是要高一些的。语句三也不错,随机获得多条记录的首选。
.
头像被屏蔽

3

主题

159

帖子

818

积分

落伍者(一心一意)

Rank: 1

贡献
911
鲜花
0
注册时间
2005-11-14
发表于 2011-3-31 17:58:19 |
提示: 作者被禁止或删除 内容自动屏蔽
签名被屏蔽

22

主题

1万

帖子

1万

积分

落伍者(四季发财)

Rank: 4

贡献
1339
鲜花
9
注册时间
2005-11-9
发表于 2011-4-1 15:45:36 |
难得一见的技术贴!
商务合作:点击这里给我发消息论坛事务:点击这里给我发消息
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号
  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2020-8-6 02:57 , Processed in 0.110672 second(s), 34 queries , Gzip On.

返回顶部