利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:
1、MySql
Select *
From
TABLE
Order
By
Rand() Limit N
以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试。
SELECT
*
FROM
`
TABLE
` a
join
(
SELECT
ROUND(RAND() * ((
SELECT
MAX
(id)
FROM
`
TABLE
`)-(
SELECT