随机读取N条记录(MySQL、SQL Server、Access、Oracle、postgreSQL)
2015-12-15 13:19
696 查看
利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:
1、MySql
Select
以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试。
2、SQL Server
Select
NewID()函数将创建一个 uniqueidentifier 类型的唯一值。
3、Access
Select
Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段(UserName)
Select
4、Oracle
1)dbms_random包
select
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql
dbms_random.value(100,200)
可以产生100到200范围的随机数
2)按概率抽取:
select
例:
select
取表Table中记录条数的10%条记录
3)sys_guid
select
5、postgreSQL
select
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
NewID()
NewID()函数将创建一个 uniqueidentifier 类型的唯一值。
3、Access
Select
TOP
N *
From
TABLE
Order
By
Rnd(ID)
Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段(UserName)
Select
TOP
N *
From
TABLE
Order
BY
Rnd(Len(UserName))
4、Oracle
1)dbms_random包
select
*
from
(
select
*
from
Table
order
by
dbms_random.value)
where
rownum < N;
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql
dbms_random.value(100,200)
可以产生100到200范围的随机数
2)按概率抽取:
select
*
from
Table
sample(百分比);
例:
select
*
from
Table
sample(10);
取表Table中记录条数的10%条记录
3)sys_guid
select
*
from
(
select
*
from
Table
orderby sys_guid())
where
rownum<N;
5、postgreSQL
select
*
from
Table
order
by
random() limit N
相关文章推荐
- 电脑上不安装Oracle时,C# 调用oracle数据库,Oracle客户工具
- oracle数据库大小写敏感配置
- Oracle中将查询的结果放入一张自定义表中的例子
- Oracle&nbsp;date类型数据
- Oracle导入dmp文件
- oracle 查询表是否包含某一给定字段
- oracle&nbsp;sql的空值null的判断…
- win7_oracle11g_64位连接32位PLSQL…
- oracle中的取余函数
- Oracle分析函数——函数RANK,DENSE_RANK,FIRST,LAST…
- 问题:oracle 计算年龄;结果:oracle中根据生日计算年龄的问题
- oracle 删除用户
- 管理口令(P):[INS-30001] ADMIN口令为空之Oracle安装
- oracle数据库之列操作
- Oracle - 基本操作之查询与创建操作
- oracle 转让日期格式字符串
- C# 读取 Oracle 数据库表的例子 SALE_REPORT
- 文章主题: 请教 oracle Instant Client 的配置
- Oracle 使用PreparedStatement防止SQL注入
- oracle dba_data_files视图字段说明