mysql随机获取一条或者多条数据
来源:互联网 发布:知乎的邀请函正文 编辑:程序博客网 时间:2024/05/16 03:22
研究一些随机的因素,主要是讲究效率问题。
语句一:
select * from users order by rand() LIMIT 1
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.048s。可是就在此时问题出现了,发现结果好像不是随机的。为了验证结果,又执行了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。经过多次验证,得出的结果都是随机的。
---------分隔线------------------------------------
结论:语句一效率不行,切忌使用。随机获得一条记录,语句二是相当不错的选择,采用JOIN的语法比直接在WHERE中使用函数效率还是要高一些的。语句三也不错,随机获得多条记录的首选。
0 0
- mysql随机获取一条或者多条数据
- MySQL随机获取一条数据
- MySql 100万级别数据中随机获取一条或多条记录之RAND()优化
- 随机获取Mysql数据表的一条或多条记录
- 随机获取Mysql数据表的一条或多条记录
- 随机获取Mysql数据表的一条或多条记录
- 随机获取Mysql数据表的一条或多条记录
- 随机获取Mysql数据表的一条或多条记录
- mysql 随机取一条或多条数据 高效率
- mysql高效率随机取一条或多条数据
- 【sql】随机获取Mysql数据表的一条或多条记录
- [Mysql数据库] MySql 获取数据表中随机一条数据
- Oracle,Mysql 随机获取N条数据
- mysql 随机获取几条数据
- 随机获得Mysql数据表的一条或多条记录
- mysql随机取表中一条数据
- MySQL随机抽取一条数据
- MySQL随机取一条数据 取指定条数的数据
- 算法复杂度
- [Language]Python中函数与函数式编程
- Linux下执行bcp指令
- Php 数组去重
- Android fragment嵌套fragment 子fragment控制父对象改变布局
- mysql随机获取一条或者多条数据
- HDU 1005 Number Sequence
- 自定义控件的自定义属性
- struts2文件上传时遇到的几个问题
- Linux Makefile与Kconfig文件详解
- iOS集成友盟统计
- 纹理特征提取方法:LBP, 灰度共生矩阵
- django获取表单数据方法
- 激活函数之tanh