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

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

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

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Q&A

解決済

4回答

318閲覧

sqlの<>について

yamaguti

総合スコア185

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

0グッド

0クリップ

投稿2017/11/18 07:22

お世話になっております。
SQLの<>について質問です。

以下のようなデータがある場合、
番号テーブル
ID CD
1  1
2 1
3 NULL

SQL

1select * from 番号テーブル 2where ID <> CD

で実行すると結果はID2のレコードのみが抽出されますか?

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

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

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

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

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

guest

回答4

0

NULLを判断するのに COL1 IS NULL, COL1 IS NOt NULL って記述できます。

Oracle null判定の方法をいくつか
SELECT 文の活用(NULL 検索)
も参考に。

SQLを実行できる環境を用意して、実際に実行しないとなかなか身に使いないことのひとつかもしれません。

投稿2017/11/18 12:02

Orlofsky

総合スコア16415

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

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

0

ベストアンサー

真が1件、偽が1件、どちらでもないものが1件で、1件ですね。

追記

Nullも含めてということなら、以下のように(IDとCDが共にNullの場合も含まれます)

SQL

1select * from 番号テーブル 2where ID <> CD or ID is Null or CD is Null

COALESCE()を使用して、Nullを空文字同等に扱うなら以下のように。
※但し、インデックスがあっても適用はされないので、その場合は上記より低速になるものと思われます。

SQL

1select * from 番号テーブル 2where coalesce(ID,'') <> coalesce(CD,'')

投稿2017/11/18 08:49

編集2017/11/20 00:21
sazi

総合スコア25173

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

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

yamaguti

2017/11/18 09:40

逆に片方はあるのに、片方はNULLのデータはどのように見つけるべきでしょうか?
sazi

2017/11/19 15:23

追記しました
guest

0

はい、<>などの普通の演算子をNULLに対して適用させると、「真でも偽でもない」という扱いになるので、条件を満たすものとはみなされません。

投稿2017/11/18 07:35

maisumakun

総合スコア145183

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

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

0

<> の条件式は「それ以外」を意味するもので

C言語でいう if (var1 != var2) とほぼ同じだと思っておけばいいです。

投稿2017/11/19 16:25

naohiro19_

総合スコア178

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問