使用Oracle分析函数随机抽取N条记录

简介:
模拟一个歌曲表,有歌曲ID和作者ID
并且初始化一些数据

  1. create table music(
  2.     music_id int primary key,
  3.     userid int
  4. );
  5. insert into music(music_id)
  6. select rownum rn from dual connect by level<1000;
  7. update music set userid= mod(music_id,5);
  8. commit;
要求:
每个作者随机抽取他的3个作品。
SQL如下
  1. select * from
  2. (
  3.     select music_id,userid,ROW_NUMBER() OVER (PARTITION BY userid ORDER BY dbms_random.random()) rn from music
  4. )
  5. where rn<=3;
第一次执行:

第二次执行:

这个方法只针对Oracle有效(使用了它的分析函数)


本文转自ICT时空 dbasdk博客,原文链接:使用Oracle分析函数随机抽取N条记录 ,如需转载请自行联系原博主。

相关文章
|
2月前
|
SQL Oracle 算法
|
4月前
|
消息中间件 关系型数据库 Kafka
实时计算 Flink版产品使用合集之oracle cdc 抽取新增一张表 可以从savepoint恢复吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
2月前
|
SQL Oracle 关系型数据库
|
2月前
|
SQL Oracle 关系型数据库
Oracle|内置函数之INSTR
【7月更文挑战第5天】
|
2月前
|
Oracle 关系型数据库 数据挖掘
|
2月前
|
Oracle 关系型数据库 数据挖掘
|
3月前
|
存储 Oracle NoSQL
Oracle中decode函数详解
Oracle中decode函数详解
|
3月前
|
Oracle 关系型数据库 大数据
oracle递归函数
oracle递归函数
|
4月前
|
SQL Oracle 前端开发
Oracle效率分析,Github标星25K+超火的前端实战项目
Oracle效率分析,Github标星25K+超火的前端实战项目
|
4月前
|
存储 NoSQL 关系型数据库
实时计算 Flink版操作报错之抽取Oracle11g时,报错: "Retrieve schema history failed, the schema records for engine ... has been removed",怎么处理
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。

推荐镜像

更多