oracle 随机抽样sample使用说明

本文介绍了如何在Oracle数据库中进行随机抽样,通过Sample功能抽取数据,适用于数据预处理和分析场景。
摘要由CSDN通过智能技术生成
这两天发了一个贴子,寻找比较好的办法随机取出表的一条记录
地址见: http://www.oracle.com.cn/viewthread.php?tid=130433&extra=page%3D1

里面讨论了一些方法,其中版主valenwon加一个ROWNUM的字段并加索引是一种相对比较有效的方法,只是要改表结构,在测试库中可以,在生产库中就不行了,本文介绍了一下ORACLE SAMPLE语法的应用,采用SAMPLE也是一种解决方法,不过还不是很好,主要是返回的记录分布不均匀,要么是靠表前面的一些,要么是不返回记录。


下面是SAMPLE语法的使用示例:

选择10%的记录
select * from t1 sample(10)
选择0.1%的记录
select * from t1 sample(0.1)

根据数据块选择1%的记录
select * from t1 sample block(1) 

使用数据块选择与使用记录行选择的区别:使用数据块选择表示样本的采集是基于数据块采集的,也就是说样本如果一个数据块被采集为样本,则数据块里的记录全部都是样本


样本统计是基于统计学采集的,是有概率问题,不一定完全准确,如你要取50%的记录,但实际可能返回给你49%的记录集,也可能返回给你51%的记录集
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值