PostgreSQL-随机查询N条记录
前言
利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:
目录
1. MySql
2. SQL Server
3. Access
4. Oracle
5. postgreSQL
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 MIN(id)FROM TABLE
))+(SELECT MIN(id) FROM TABLE
)) AS id) AS b WHERE a.id >= b.id ORDER BY a.id LIMIT N;
2、SQL Server
Select TOP N * From TABLE Order By