随笔分类 -  SQL

摘要:MYSQL的随机抽取实现方法。举个例子,要从tablename表中随机提取一条记录,大家一般的写法就是:SELECT * FROM tablename ORDER BY RAND() LIMIT 1。但是,后来我查了一下MYSQL的官方手册,里面针对RAND()的提示大概意思就是,在ORDER BY从句里面不能使用RAND()函数,因为这样会导致数据列被多次扫描。但是在MYSQL 3.23版本中,仍然可以通过ORDER BY RAND()来实现随机。但是真正测试一下才发现这样效率非常低。一个15万余条的库,查询5条数据,居然要8秒以上。查看官方手册,也说rand()放在ORDER BY 子句中 阅读全文
posted @ 2013-06-20 10:26 暗夜独游Jevil 阅读(2008) 评论(0) 推荐(0)
摘要:一直以为MySQL随机查询几条数据,就用SELECT * FROM 'table' ORDER BY RAND() LIMIT 5就可以了。但是真正测试一下才发现这样效率非常低。一个15 万余条的库,查询5条数据,居然要8秒以上 查看官方手册,也说rand()放在ORDER BY 子句中会被执行多次,自然效率及很低。 You cannot use a column with RAND() values in an ORDER BY clause, because ORDER BY would evaluate the column multiple times. 搜索Googl 阅读全文
posted @ 2013-04-01 14:52 暗夜独游Jevil 阅读(400) 评论(0) 推荐(0)