数据库

MySQL中随机获取数据以及效率

作者:admin 来源:web交流网 2018-09-15 18:04 浏览:0 我要评论(0)

我现在主要以users(userId,userName,password )表(有一百多万条记录)为例:第一种:select * from users order by rand()

我现在主要以users(userId,userName,password......)表(有一百多万条记录)为例:
 
第一种:
select * from users order by rand() LIMIT 1
执行该sql语句,老半天没有反应,最后被迫手动停止执行 ,后来我查了一下MYSQL手册,里面针对RAND()的提示大概意思就是,在ORDER BY从句里面不能使用RAND()函数,
因为这样会导致数据列被多次扫描,导致效率相当相当的低!效率不行,切忌使用!

第二种:
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.048,给力吧。
可是就在此时问题出现了,发现结果好像不是随机的?为了验证结果,又执行了N次,真不是随机的, 问题出现在”ORDER BY t1.userId“这里,按userId排序了。
随机取一条记录还是不错的选择,多条就不行了啊!
 
第三种:
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。经过多次验证 !
 
结论:随机取一条或多条记录,方法都不错!
结论:方法1效率不行,切忌使用;随机获得一条记录,方法2是相当不错的选择,采用JOIN的语法比直接在WHERE中使用函数效率还是要高一些的,不过方法3也不错;
随机获得多条记录,方法3没说的!
 
方法3加上条件
$where = '1=1'
SELECT * FROM users WHERE userId >= ((SELECT MAX(userId) FROM users WHERE '.$where.')-(SELECT MIN(userId) FROM users WHERE '.$where.')) * RAND() + (SELECT MIN(userId) FROM users WHERE '.$where.') AND '.$where.' LIMIT 1

转载请注明出处。

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • mysql 随机取一条或多条数据 高效率

    mysql 随机取一条或多条数据 高效率

    2018-05-07

  • sql分页查询效率慢的问题分析及处理

    sql分页查询效率慢的问题分析及处理

    2018-09-15

  • MySQL数据类型总结

    MySQL数据类型总结

    2016-04-28

  • phpmyadmin数据库导入文件大小限制怎么改?

    phpmyadmin数据库导入文件大小限制怎么改?

    2016-04-30

  • mysql互换表中两列数据方法

    mysql互换表中两列数据方法

    2016-09-13

网友点评
评论(已有0条评论)
还没有评论,快来抢沙发吧!
新闻
  • 新闻
  • 软件
精彩导读