从Oracle库表中取任意的n条数据

本文讨论了一种从数据库中随机选取指定数量记录的SQL语句,虽然该方法能够实现目标,但作者认为其效率较低。文章呼吁读者分享更高效的解决方案,以提升随机取数的性能。

select * from tablename order by dbms_random.value) where rownum<=n

测试可以使用,但是感觉效率不高,希望有高效率的办法的多多指点。

转载于:https://my.oschina.net/nly/blog/336098

<think>我们之前已经讨论过在Oracle 10g中前2条数据的方法,主要使用ROWNUM。这里再详细说明一下。 在Oracle 10g中,没有像MySQL的LIMIT或Oracle 12c的FETCH FIRST这样的语法,所以通常使用ROWNUM来实现。 注意:ROWNUM是在查询结果返回之前分配的,因此不能直接在WHERE子句中使用ROWNUM>某个数(比如第3到5),但可以用子查询来实现分页。 现在,针对“10条数据中的2”,我们可以理解为前2,或者任意2?但通常我们是指前2(按某种顺序或默认顺序)。 如果不需要排序,直接前2,那么: SELECT * FROM table_name WHERE ROWNUM <= 2; 但是,如果需要按某个字段排序后前2,那么就需要在子查询中先排序,再使用ROWNUM。 下面给出两种情况的代码和解释:</think>### Oracle 10g 中前 2 条数据的解决方案 在 Oracle 10g 中,可以使用 `ROWNUM` 伪列或 `ROW_NUMBER()` 分析函数实现只前 2 条数据。以下是两种方法的详细实现: #### 方法 1:使用 `ROWNUM`(推荐) ```sql SELECT * FROM ( SELECT t.* FROM your_table t -- 替换 your_table 为实际名 WHERE ROWNUM <= 2 -- 直接限制行数 ); ``` #### 方法 2:使用 `ROW_NUMBER()`(带排序) ```sql SELECT * FROM ( SELECT t.*, ROW_NUMBER() OVER (ORDER BY your_column) AS rn -- 替换 your_column 为排序列 FROM your_table t ) WHERE rn <= 2; ``` ### 代码解释 1. **`ROWNUM` 方法**: - `ROWNUM` 是 Oracle 自动为查询结果分配的行号(从 1 开始) - 直接在 `WHERE` 子句中使用 `ROWNUM <= 2` 过滤前 2 行 - **优点**:简单高效,不需要子查询嵌套 - **限制**:无法直接指定排序顺序 2. **`ROW_NUMBER()` 方法**: - `ROW_NUMBER() OVER (ORDER BY ...)` 为排序后的结果分配序号 - 外层查询通过 `WHERE rn <= 2` 过滤前 2 行 - **优点**:支持自定义排序规则 - **适用场景**:需要按特定顺序(如时间倒序)前 N 记录 ### 示例场景 假设有 `employees`,获前 2 记录: ```sql -- 方法 1:直接前 2 SELECT employee_id, first_name, last_name FROM employees WHERE ROWNUM <= 2; -- 方法 2:按工资降序前 2 名 SELECT * FROM ( SELECT employee_id, first_name, salary, ROW_NUMBER() OVER (ORDER BY salary DESC) AS rnk FROM employees ) WHERE rnk <= 2; ``` ### 注意事项 1. `ROWNUM` 是在数据**返回前**分配的,件 `ROWNUM = 2` 无效(需用 `<=`) 2. 分页查询需结合子查询(如第 3-5 ): ```sql SELECT * FROM ( SELECT t.*, ROWNUM AS rn FROM your_table t WHERE ROWNUM <= 5 -- 上限 ) WHERE rn >= 3; -- 下限 ``` 3. Oracle 12c+ 可使用更简洁的 `FETCH FIRST 2 ROWS ONLY` 语法 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值