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総合スコア1307
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;
COL1 | COL2 |
---|---|
1 | 2 |
- | 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
総合スコア594
良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
このような回答には修正を依頼しましょう。
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;
投稿2022/12/08 15:59
総合スコア16248
良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
このような回答には修正を依頼しましょう。
0
「NVL、COALESCE」
https://www.shift-the-oracle.com/sql/functions/nvl-coalesce.html
NVL は ORACLE の方言なので COALESCE を使うようにしたほうが良いと思います。
投稿2022/12/08 14:58
総合スコア2252
良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
このような回答には修正を依頼しましょう。
関連した質問
解決済
回答2
クリップ1
更新
2023/01/30
C# DataGridViewで選択したセルの行のボトムに赤い罫線を引きたい、ができません。
解決済
回答3
クリップ0
更新
2023/01/26
JSで変数に非同期で取得した値を格納したい。
解決済
回答1
クリップ0
更新
2023/01/26
railsのAPIモードで、ID以外のカラムで削除したい。
解決済
回答2
クリップ1
更新
2023/01/22
最速で配列からデータを取り出し、正規表現で検索したい。
解決済
回答1
クリップ0
更新
2023/01/28
pythonでmysqlデータベースに日付をINSERTしたい
受付中
回答2
クリップ2
更新
2023/01/22
Dataframe.queryの結果がカラム名によって異なる
解決済
回答1
クリップ1
更新
2023/01/26
Linuxのcronでメモリ開放を定期実行したい
解決済
回答1
クリップ0
更新
2023/01/25
SQL*LoaderでのCSV取り込み時、1つ目のカラム末尾の囲み文字が消えない
同じタグがついた質問を見る
Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。
A5:SQL Mk-2は、フリーのSQL開発ツールです。高機能で軽量、且つ分かりやすいことを目指して開発されました。SQLの実行やテーブル編集などの機能に加え、簡単な操作によりDB定義書やER図を自動生成することも可能です。
良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。
下記のような回答は推奨されていません。
このような回答には修正を依頼しましょう。
こちらの回答が他のユーザーから「質問に対する回答となっていない投稿」という指摘を受けました。