Oracle中的NULL(一、问题引入)
生活随笔
收集整理的這篇文章主要介紹了
Oracle中的NULL(一、问题引入)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
2019獨角獸企業重金招聘Python工程師標準>>>
說明:最近在寫后臺程序的時候,遇到了關于Oracle中NULL的一個問題:
測試數據
表結構:
表中已有的數據:
插入數據:
INSERT INTO Z_TEST VALUES ('', '堅毅童'); 這是表中的數據為:
當我想把'FSTUDENTNAME' 為 '堅毅童'的記錄查出來:
SELECT T.*, T.ROWID FROM Z_TEST T WHERE T.FSTUDENTID = '';
但結果為:
查詢無記錄。
這時我就在想,我明明把這條數據的FSTUDENTID字段置為'',但是卻查不出來。后來我想 ,Oracle是不是把這個空字符串編程了NULL。
為了驗證我想法的正確性,我測試了一下:
SELECT DECODE(T.FSTUDENTID, NULL, 'NULL值', '空字符串')FROM Z_TEST TWHERE T.FSTUDENTNAME = '堅毅童'; 發現,我的猜想是正確的,原來Oracle把空字符串解析成了NULL。
我在程序中調用存儲過程,插入數據字段為''空字符串,結果該字段就變成了NULL;
后來我為了找問題的解釋,就在網上搜了很多的資料,下面就把這些資料整理一下。
轉載于:https://my.oschina.net/eillenme/blog/101519
總結
以上是生活随笔為你收集整理的Oracle中的NULL(一、问题引入)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 介绍Windows Server服务器角
- 下一篇: JS 全局对象 全局变量 作用域 (改自