🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
COUNT

COUNT は、広く使用されているSQLの関数です。COUNT関数は、行数、もしくは配列のエンティティの数をカウントします。

GROUP BY

GROUP BYとはSQL文のひとつで、SELECT文において特定の列の値が等しい行ごとに表をグループ化します。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Q&A

解決済

2回答

4194閲覧

SQLServer COUNTでCASE時の値取得

kakukaku123

総合スコア9

COUNT

COUNT は、広く使用されているSQLの関数です。COUNT関数は、行数、もしくは配列のエンティティの数をカウントします。

GROUP BY

GROUP BYとはSQL文のひとつで、SELECT文において特定の列の値が等しい行ごとに表をグループ化します。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

0グッド

0クリップ

投稿2021/01/06 06:28

前提・実現したいこと

SQLServerにて、A列の件数により処理を分岐したいと思っています。
1件:B列を表示
複数件:n件を表示

――――――
A | B
――――――
1 | aaa
2 | bbb
3 | ccc
1 | ddd

――――――
A | B
――――――
1 | 2件
2 | bbb
3 | ccc

該当のソースコード

SELECT
[A],
CASE COUNT([A])
WHEN 1 THEN [B]
ELSE CONVERT(VARCHAR, COUNT([A])) + '件'
END
FROM テーブル
GROUP BY [A]
→B列がGROUP BY句に含まれていないというエラーになってしまう

SELECT
[A],
CASE COUNT([A])
WHEN 1 THEN [B]
ELSE CONVERT(VARCHAR, COUNT([A])) + '件'
END
FROM テーブル
GROUP BY [A], [B]
→[A]列が同じでも複数列表示される

どのようなSQLで実現可能でしょうか。

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

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

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

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

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

guest

回答2

0

ベストアンサー

SQL

1SELECT 2[A], 3CASE COUNT([A]) 4WHEN 1 THEN MAX([B]) 5ELSE CONVERT(VARCHAR, COUNT([A])) + '件' 6END 7FROM テーブル 8GROUP BY [A]

投稿2021/01/06 13:26

iruyas

総合スコア1067

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

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

kakukaku123

2021/01/06 23:38

なるほど! [B]列も適当に集計関数でくくればいいんですね 無事解決できました。 ありがとうございます。
guest

0

どのようなSQLで実現可能でしょうか。

すぐ思いつく一番単純な方法は2件以上のものと1件しかないものをそれぞれ自分が出力したい形で取得するクエリを作ってUNIONする。

投稿2021/01/06 07:05

gentaro

総合スコア8947

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

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

kakukaku123

2021/01/06 23:40

方法を検討/ご教示いただきありがとうございます。 今回はiruyasさんの回答にて対応したいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問