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

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

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

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

Q&A

解決済

3回答

2252閲覧

SQL CASE文でできた空白を詰めたい

cn49cst6

総合スコア13

SQL

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

0グッド

0クリップ

投稿2019/03/06 11:30

取得した結果を横1行に表示させたいのですが、斜めに表示されてしまいます
ORDER BYも試したのですが上手くいかず、空白の部分も条件分岐によって表示されていないだけで実際には値が入っていることはわかりました
ですがそこからがどう処理すればいいか分からず質問させていただいた次第です
テーブル名(abc)
カラム名(hoge)
hogeの中身(4,6,8)
·····固定の整数
(DB2)
SELECT
case when hoge = 4 then hoge else null end as 区分,
case when hoge = 8 then hoge else null end as 区分,
case when hoge = 6 then hoge else null end as 区分,
FROM(SELECT hoge FROM abc WHERE hoge IN('4',
'6','8'))
GROUP BY hoge
;

学び始めなこともあり冗長なコードではありますがよろしくお願いします

——————————
|hoge|hoge|hoge|
——————————
|4 | | |
——————————
| |6 | |
——————————
| | | 8 |

——————————
|hoge|hoge|hoge|
——————————
|4 | 6 | 8 |
——————————
理想としてこの図のような形にさえなれば大丈夫です

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

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

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

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

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

m.ts10806

2019/03/06 11:35

テーブル定義のCREATE TABLE文、サンプルデータのINSERT文を提示された方がより的確な回答が得られると思います。 データについても「hogeの中身(4,6,8)」では状況わかりづらいですし(並列に見える)、マークダウンのテーブル機能もご利用ください。 また、コードはマークダウンのcode機能をご利用ください。 ※質問は編集可能です
m.ts10806

2019/03/06 11:37

あと質問文にちょっと入ってる「DB2」が利用されているDBですかね? SQLは文法に方言があるので、タグも利用されているものに合わせたほうが良いかと思います。 ※タグは最大5つまで適用できるのでSQLは入れておいてもよいと思います。追加ですね。 あと、学びはじめとのことなので「初心者マーク」つけられたほうが良いですね。
cn49cst6

2019/03/10 03:15

ありがとうございます。気をつけたいと思います
m.ts10806

2019/03/10 03:44

質問を編集してくださればそれで良いのですが…
guest

回答3

0

なにかおかしい

  • 例えば4が複数あったらどうするのか?
  • 値がなかったらどうするのか?

元データ

SQL

1create table tbl(id int,val int); 2insert into tbl values(1,4),(2,6),(3,8),(4,4); 3

結果

SQL

1select 2(select distinct val from tbl where val=4) as c4, 3(select distinct val from tbl where val=5) as c5, 4(select distinct val from tbl where val=6) as c6, 5(select distinct val from tbl where val=8) as c8;

投稿2019/03/07 03:22

yambejp

総合スコア114829

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

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

0

CREATE TABLE を提示しては?
hoge カラムは数値でしょうか?文字列なら定数はシングルクォートで囲んでください。

SQL

1SELECT 2 case when hoge = 4 then hoge end as hoge4 3 , case when hoge = 8 then hoge end as hoge8 4 , case when hoge = 6 then hoge end as hoge6 5FROM( 6 SELECT hoge FROM abc WHERE hoge = 4 7 UNION ALL 8 SELECT hoge FROM abc WHERE hoge = 6 9 UNION ALL 10 SELECT hoge FROM abc WHERE hoge = 8 11 ) 12;

投稿2019/03/06 14:14

Orlofsky

総合スコア16415

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

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

0

ベストアンサー

GROUP BY hogeとなっていますので、hogeのパターン数分の行になります。
全体で纏めたいならGROUP BYは不要です。

SQL

1SELECT Max(case when hoge='4' then hoge end) as hoge4 2 , Max(case when hoge='8' then hoge end) as hoge8 3 , Max(case when hoge='6' then hoge end) as hoge6 4FROM abc 5WHERE hoge IN('4','6','8')

質問ではhogeを条件にhogeをしていますが、実際には違うんでしょうね。

投稿2019/03/06 13:26

編集2019/03/06 13:27
sazi

総合スコア25186

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

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

cn49cst6

2019/03/10 03:08

遅くなり申し訳ありません 稚拙な文章や足りない情報を補っていただきありがとうございます なんとか参考にして解決することが出来ました 又、他の方も回答ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問