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

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

新規登録して質問してみよう
ただいま回答率
86.12%
Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

A5:SQL Mk-2

A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。

解決済

カラムがnullの場合

ponpon888
ponpon888

総合スコア2

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

A5:SQL Mk-2

A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。

4回答

0グッド

0クリップ

317閲覧

投稿2022/12/08 14:39

tableのpがありまして、pのカラム1とカラム2があるとします。
取出したいときに
カラム1がnullだった場合、カラム2の値をセットしたいのですが、手法が不明です。
sqlのみでできるのでしょうか?

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

回答4

0

sql

1UPDATE p SET colum1 = colum2 WHERE colum1 IS NULL;

投稿2022/12/09 02:10

編集2022/12/09 07:26
yuma.inaura

総合スコア1307

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

2022/12/09 07:24依頼された後にこの回答は修正されています

こちらの回答が他のユーザーから「質問に対する回答となっていない投稿」という指摘を受けました。

0

ベストアンサー

回答ではありません

一応いろいろ試した結果を貼っておきますね。
ここまでの回答をどうこうするものではありません。

準備

sql

1drop table sample; 2create table sample(col1 varchar2(10), col2 varchar2(10)); 3insert into sample values('1', '2'); 4insert into sample values(NULL, '3'); 5insert into sample values('4', NULL); 6insert into sample values(NULL, NULL); 7commit;

内容確認

sql

1select * from sample;
COL1COL2
12
-3
4-
--

sql

1select nvl(col1, col2) as example from sample; 2select nvl2(col1, col1, col2) as example from sample; 3select coalesce(col1, col2) as example from sample; 4select case when col1 is not null then col1 else col2 end as example from sample;
EXAMPLE
1
3
4
-

全て同じ

投稿2022/12/08 16:17

dameo

総合スコア594

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

2022/12/09 00:35

こちらの回答が他のユーザーから「質問に対する回答となっていない投稿」という指摘を受けました。

回答へのコメント

KOZ6.0

2022/12/08 20:01

decode も仲間に入れてあげてください
dameo

2022/12/08 21:21

coalesceとdecodeはほとんど見ないので・・・
dameo

2022/12/09 00:39

毎度わざわざ本文に書いてることを指摘してくる人がいますね。よく読んで下さいね。
dameo

2022/12/09 02:21

これは回答ではなく補足なので、すみませんがベストアンサーは別の人にしてください

0

tableのpがありまして、pのカラム1とカラム2があるとします。

CREATE TABLE文で提示できるようになってください。
質問に明示されていないので2つの列を共にVARCHAR2(10)と想定して以下に記述します。
SQL言語リファレンス CREATE TABLE

SQL

1CREATE TABLE P(COL1 VARCHAR2(10), COL2 VARCHAR2(10)); 2 3SELECT NVL(COL1, COL2) AS COL1 FROM P;

SQL言語リファレンス ファンクション NVL

投稿2022/12/08 15:59

Orlofsky

総合スコア16248

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

0

「NVL、COALESCE」
https://www.shift-the-oracle.com/sql/functions/nvl-coalesce.html
NVL は ORACLE の方言なので COALESCE を使うようにしたほうが良いと思います。

投稿2022/12/08 14:58

KOZ6.0

総合スコア2252

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

A5:SQL Mk-2

A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。