ROW_NUMBER()を使用してORDERした結果の5行目から10行目を
取得したい場合、どこのサイトを参照しても下記(1)のように
NOで並び替えたデータをインラインビューとして
WHERE RNUM BETWEEN 5 AND 10
と条件を絞っていますが、(2)のように直接条件を指定した場合と
どのような違いがあるのか教えてください。
(1)
SELECT NO, NAME FROM (
SELECT NO, NAME,
ROW_NUMBER() OVER (ORDER BY NO) RNUM
FROM ROWNUM_TEST
) WHERE RNUM BETWEEN 5 AND 10
(2)
SELECT NO, NAME,ROW_NUMBER() OVER (ORDER BY NO) RNUM
FROM ROWNUM_TEST
WHERE RNUM BETWEEN 5 AND 10
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
補足ですが、リンクをご覧ください(OTN)。
>分析ファンクションは、問合せで最後に実行される演算(最後のORDER BY句を除く)の集合です。すべての結合およびすべてのWHERE、GROUP BYおよびHAVING句は、分析ファンクションが処理される前に実行されます。そのため、分析ファンクションは、SELECT構文のリストまたはORDER BY句のみに指定できます。
ROW_NUMBERは分析関数またはウィンドウ関数といわれ、抽出条件に直接指定することはできないのです。
参考URL:http://otndnld.oracle.co.jp/document/products/or …
No.1
- 回答日時:
こんにちは。
2を実行してみましたか?
私はOracle9と10しか環境がありませんのでその範囲での答えですが、
SELECT NO, NAME,ROW_NUMBER() OVER (ORDER BY NO) RNUM
FROM ROWNUM_TEST
WHERE RNUM BETWEEN 5 AND 10
のように抽出列をリネームした場合(この場合はRNUMです)
その新しい名前は同じ階層のSELECT文のWHERE条件として指定することができません。
下はROW_NUMBER()を外した例ですが、
SELECT GAKUSEI_CODE AS CODE, GAKUSEI_NAME
FROM GAKUSEI_TABLE
WHERE CODE BETWEEN 1 AND 10
として実行した場合 ORA-00904が発生します。
この場合は、
SELECT GAKUSEI_CODE AS CODE, GAKUSEI_NAME
FROM GAKUSEI_TABLE
WHERE GAKUSEI_CODE BETWEEN 1 AND 10
としなければなりません。
話を戻しますが、上記理由でWHERE RNUM BETWEEN 5 AND 10という条件は使用できません。
また、WHERE ROW_NUMBER() OVER (ORDER BY NO) BETWEEN 5 AND 10
という書き方も、ORA-30483が発生してエラーとなります。
よってROW_NUMBER()を指定する場合1のような書き方となるのではないでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP PHP MySql ページング 2 2022/09/20 06:38
- MySQL 下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 「名前(first name) 1 2023/06/24 13:03
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- Access(アクセス) アクセス 有効なフィールド名、または式として認識できませんのエラー 3 2022/08/19 11:53
- PHP コメント機能に返信欄を矢印で追加したい 1 2022/05/09 21:17
- PHP php my adminより取り出したデータ表示 2 2022/06/15 11:56
- Oracle SQL update方法 2 2022/06/22 14:07
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- Access(アクセス) MAXで0が出力される 1 2022/03/31 21:43
- Visual Basic(VBA) エクセル VBA 難しいです 1 2023/02/21 15:39
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
質問:DBMS_OUTPUTの使用方法
-
ストアドプロシジャからストア...
-
時間項目を60進数から10進数へ...
-
GET_DDLについて
-
Accessのマクロでモジュールを...
-
エクセルVBAでUserFormを起動し...
-
Access VBAで行ラベルが定義さ...
-
会社の〇〇部と〇〇課の違いっ...
-
エクセル 日付による並べ替え...
-
SQLサーバで和暦から西暦に変換...
-
キャッシュを使わずにSELECTを...
-
SQLで部分的にGROUP BYしたいとき
-
百の位での四捨五入について
-
SQLserver算術オーバーフロ...
-
wordの差し込み印刷での日付表示
-
sqlplusのspoolで空白行出現
-
Accessの数値から時間に変換す...
-
全角空白のTRIMができない...
-
SQLite3のtext→date変換について
-
Statement ignored というエラー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ストアドプロシジャからストア...
-
時間項目を60進数から10進数へ...
-
ストアド実行時のエラー「参照...
-
PL/SQL exceptionを呼び出すには?
-
ROW_NUMBER()を使用したデータ取得
-
ストアドプロシージャからアナ...
-
質問:DBMS_OUTPUTの使用方法
-
PL/SQLで連結(||)と結合(=>)の違い
-
ストアドプロシージャからスト...
-
パッケージ内のファンクション...
-
PL/SQLのファンクションでのOUT...
-
INSERT文の書式
-
PL/SQL 実行中のSID
-
PL/SQLの例外
-
GET_DDLについて
-
Function内に記述したdbms_outp...
-
Oracle: PACKAGE BODY の分割
-
OracleのTEXT_IOについて
-
動的SQL
-
PL/SQLについて
おすすめ情報