質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

2回答

1134閲覧

集約関数と分析関数の併用はできる?

kanitama111

総合スコア8

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2021/08/18 10:02

編集2021/08/18 10:04

下記のような集約関数と分析関数を併用するSQLを作成しましたが、
「ORA-00979:GROUP BYの式ではありません。」のエラーが発生してしまいます。

過去の質問(https://teratail.com/questions/88199)のベストアンサーを参考に
下記SQLのMAX(a.売上担当者名)をMAX(MAX(a.売上担当者名))でネストしてみましたが同じエラーが発生します。
なにかよい方法ありませんでしょうか。

▼作成したSQL

SELECT a.売上年月 ,MAX(a.売上担当者名) keep (dense_rank last ORDER BY a.売上明細番号) over(partition by a.売上年月, a.売上番号) AS 売上担当者名 FROM 売上テーブル a GROUP BY a.売上年月

▼売上テーブル
|売上年月|売上番号|売上明細番号|売上担当者名|
|:--|:--:|--:|
|2021/01|01|01|田中太郎|
|2021/01|01|02|田中太郎|
|2021/01|01|03|山田花子|
|2021/02|01|01|鈴木一郎|

▼期待する結果

売上年月売上担当者名
2021/01山田花子
2021/02鈴木一郎

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mather

2021/08/18 10:43

期待する結果になるためのロジックを具体的に言葉で書いてみてください。 「売上年月ごとに○○を満たす売上担当者名を一行ずつ取得する」
kanitama111

2021/08/18 10:50

投稿ありがとうございます。 ロジックとしては下記になります。 「売上年月、売上番号単位で売上明細番号が最大の売上担当者名を1行ずつ取得する」
sazi

2021/08/19 02:38

>「売上年月、売上番号単位で売上明細番号が最大の売上担当者名を1行ずつ取得する」 それなら、期待する結果に売上番号も必要なのでは?
guest

回答2

0

売上担当者名=鈴木一郎のデータについては、売上番号は"01"ではないという認識で正しいでしょうか?

以下のようなSQLで実現できると思います (OVER句が不要かと思います)。

SQL

1SELECT 2 売上年月, 3 MAX(売上担当者名) KEEP (DENSE_RANK LAST ORDER BY 売上明細番号) AS 売上担当者名 4FROM 売上テーブル 5GROUP BY 売上年月, 売上番号

投稿2021/08/18 11:06

編集2021/08/18 11:15
neko_the_shadow

総合スコア2349

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kanitama111

2021/08/18 11:16

回答ありがとうございます。 それですと売上年月、売上番号単位での明細番号の取得にはならないのではないでしょうか。 例えば、売上年月2021/01、売上番号02、売上明細番号04のデータが存在する場合、 売上年月2021/01、売上番号01の売上担当者名に売上番号02の売上担当者名が紐付けられるかと思います。
neko_the_shadow

2021/08/18 11:27

やりたいことを一度整理させてください。 ① 同じ売上年月と売上番号を持つデータをひとつのグループとする。 ② ①でまとめたグループの中で売上明細番号が最大の売上担当者を取得する。 ↑があっていますでしょうか? であれば、回答に提示したSQLで実現可能かと思います。 また、実際に実行してみてどのような問題があったかについてフィードバックできますでしょうか? > 売上担当者名=鈴木一郎のデータについては、売上番号は"01"ではないという認識で正しいでしょうか? すみません。こちらについては無視してください。わたしの勘違いかもしれません。
guest

0

こんな感じになるのではないでしょうか。

SELECT a.売上年月, a.売上担当者名 FROM 売上テーブル a WHERE (a.売上年月, a.売上番号, a.売上明細番号) IN (SELECT 売上年月, 売上番号, MAX(売上明細番号) as 売上明細番号 FROM 売上テーブル GROUP BY 売上年月, 売上番号 )

投稿2021/08/18 10:57

mather

総合スコア6759

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kanitama111

2021/08/18 11:16

ご回答ありがとうございます。 質問内容に前提条件が漏れておりましたので追記させていただきます。
mather

2021/08/18 12:02

追記しましたか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問