[解決済み] [Solved] Oracle 9iはなぜ空の文字列をNULLとして扱うのですか?
質問
私はそれを知っている
を行います。
を ' と見なします。
NULL
しかし、これだけでは
なぜ
ということになります。 私が理解しているSQLの仕様では、' 'は、' 'と同じではありません。
NULL
-- 一方は有効なデータで、もう一方はその同じ情報がないことを示すものです。
推測は自由ですが、そうであればご指摘ください。 オラクルからコメントできる人がいれば、それは素晴らしいことです。
どのように解決するのですか?
その答えは、Oracleがとてもとても古いからだと思います。
その昔、標準SQLがなかった頃、Oracleは、空文字列の
VARCHAR
/
VARCHAR2
の列は
NULL
であり、NULLの意味は1つだけである(関係理論家は、一度も入力が促されたことのないデータ、答えは存在するがユーザが知らないデータ、答えが存在しないデータなどを区別しており、これらはすべて何らかの意味で
NULL
).
標準SQLが登場し、以下のような合意がなされるまでに。
NULL
と空文字列は別物であるとするコードを持つOracleユーザが既に存在していたのです。 そのため、オラクルは基本的に、既存のコードを壊すか、標準SQLに違反するか、ある種の初期化パラメータを導入して潜在的に多くのクエリの機能を変更するかという選択肢に迫られました。 標準SQLに違反することは(IMHO)、これら3つのオプションのうち最も破壊的でないものでした。
オラクルは
VARCHAR
のデータ型は、将来のリリースで標準SQLに準拠するように変更される可能性があります(そのため、誰もが
VARCHAR2
のデータ型の動作は今後も変わらないことが保証されているので、Oracleで使用することができます)。
関連
-
[解決済み] なぜパスワードにはStringではなくchar[]が好まれるのですか?
-
[解決済み] Pythonには文字列の'contains'サブストリングメソッドがありますか?
-
[解決済み] JavaScriptで空文字列/未定義文字列/null文字列をチェックするにはどうすればよいですか?
-
[解決済み] なぜlist.join(string)ではなくstring.join(list)なのでしょうか?
-
[解決済み] 文字列が空かどうかを確認する方法は?
-
[解決済み] ランダムな文字列を使用するこのコードは、なぜ "hello world" と表示されるのですか?
-
[解決済み] と'is'のどちらかを使って文字列を比較すると、異なる結果になることがあるのはなぜですか?
-
[解決済み] Stringでswitch文が使えないのはなぜですか?
-
[解決済み] nullはなぜオブジェクトなのか、nullとundefinedの違いは何ですか?
-
[解決済み] PowerShellで文字列がNULLまたは空であるかどうかを確認するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】オペランド型の衝突:intはdateと互換性がない + INSERT文はFOREIGN KEY制約と衝突した
-
[解決済み】一括読み込みデータ変換エラー(指定されたコードページに対して型の不一致または無効な文字)1行目4列目(年)について)
-
[解決済み】INTERSECTとINNER JOINは根本的に違うのか?[重複している]
-
[解決済み】SQL Server: 無効なカラム名
-
[解決済み] データ型 varchar の変換エラー
-
[解決済み] WHERE x IN (5) vs WHERE x = 5 ...なぜINを使うのか?
-
[解決済み] ORA-04063: ビューにエラーがあります
-
[解決済み] ora-06553 pls-306 'ogc_x' の呼び出しで引数の数または種類が誤っている。
-
[解決済み] 検索エラー ORA-00932: 不整合なデータ型: 期待された DATE は NUMBER になりました。
-
[解決済み] PostgreSQL - json 型の等値演算子を識別できませんでした。