線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:5754
推到 Plurk!
推到 Facebook!

是null 還是空字串

尚未結案
will
中階會員


發表:176
回覆:135
積分:62
註冊:2002-04-14

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-12-18 05:09:36 IP:211.72.xxx.xxx 未訂閱
對於一個字串型態的欄位而言 null='' 嗎? 小弟做了一個實驗 有一table 有三個欄位GradeID(int *), Grade(A4), Years(int) 其中GradeID 為Primary Key 小弟將這個table 連接到dbGrid 在dbGrid新增一筆資料 但只給GradeID一個值, Grade, Years 都不給值 用if 去判斷時發現 Grade 是'' 也是 null(用isNull 判斷) Years 是0 也是null 好奇怪 以前的觀念裡 '' 和null , 0 和null 是不一樣的
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-12-18 08:57:31 IP:210.65.xxx.xxx 未訂閱
Hi:    在 DataBase 與 Delphi 中,NULL 所代表得定義是不一樣的 在 DataBase(Oracle,SQL Server) 中,NULL 代表的是不是任何東西,也就是說,NULL 不等於任何東西,你可以試試 select * from table where null = null 你會發現,理論上你應該會得到該 Table 的所有紀錄,但事實上卻是相反,你得不到任何紀錄,原因就是因為先前所說的,『NULL 不等於任何東西』    但是在 Delphi 中 Query2.FieldByName('欄位').AsString --> 若欄位內容為 null,會轉為 '' Query2.FieldByName(欄位').AsInteger --> 若欄位內容為 null,會轉為 0     -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
will
中階會員


發表:176
回覆:135
積分:62
註冊:2002-04-14

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-12-19 09:13:10 IP:61.221.xxx.xxx 未訂閱
那在Delphi中就無法判斷後端的資料庫欄位的值是null 還是空字串了 (好像也沒有必要)    Hi:    在 DataBase 與 Delphi 中,NULL 所代表得定義是不一樣的 在 DataBase(Oracle,SQL Server) 中,NULL 代表的是不是任何東西,也就是說,NULL 不等於任何東西,你可以試試 select * from table where null = null 你會發現,理論上你應該會得到該 Table 的所有紀錄,但事實上卻是相反,你得不到任何紀錄,原因就是因為先前所說的,『NULL 不等於任何東西』    但是在 Delphi 中 Query2.FieldByName('欄位').AsString --> 若欄位內容為 null,會轉為 '' Query2.FieldByName(欄位').AsInteger --> 若欄位內容為 null,會轉為 0     -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 -------------------------------- [/
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-12-19 09:34:23 IP:210.65.xxx.xxx 未訂閱
Hi:    事實上,Delphi 有辦法判斷後端的資料庫欄位的值是null 還是空字串,可以用    Query3.FieldByName('department_code').AsVariant = NULL     -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-12-19 09:35:10 IP:63.84.xxx.xxx 未訂閱
您好﹗    小弟覺得還是可以判斷的﹐因為Null和空字串本來就是兩個完全不同意義的東東﹒您可利用Query元件或ADOQuery元件和相關的SQL語法做個測試﹕
begin
  Query1.Close;
  Query1.SQL.Text := 'Select * From 資料表 Where 欄位1 is Null';
  //Query1.SQL.Text := 'Select * From 資料表 Where 欄位1='';
  Query1.Open;
end;
以上下SQL語法的時候﹐紅色處和藍色處找到的資料不會一樣﹕ 紅色處﹕只要資料表中任何一筆資料的欄位1未輸入過任何值時(或者說輸入焦點未進入到此欄位)﹐這個欄位值就是Null﹒ 藍色處﹕只要資料表中任何一筆資料的欄位1有輸入過值(或者說輸入焦點有進入到此欄位)﹐但又對此欄位做了清空的動作﹐這個欄位值就是空字串﹒ 在反過來講﹐同Fishman兄所言﹐如果沒有使用ASString等指定形態的函數﹐僅僅用Value自動判斷形態的函數時﹐當欄位值為Null時﹐一旦做了運算或者相關的動作﹐程式即會出錯﹒ 參考看看﹗ ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
ccchen
版主


發表:61
回覆:940
積分:1394
註冊:2002-04-15

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-12-19 09:48:47 IP:218.163.xxx.xxx 未訂閱
用if 去判斷時發現 Grade 是'' 也是 null(用isNull 判斷) Years 是0 也是null 好奇怪 以前的觀念裡 '' 和null , 0 和null 是不一樣的 主要是看你如何去判斷的 如果是直接 DataSet[FieldName], 或 DataSet.fieldbyname(fieldname).value或 DataSet.fieldbyname(fieldname).asVariant則其結果是Variant, 故如果沒有值, 會保持null狀態 如果你用 DataSet.fieldbyname(fieldname).asString無論原來是什麼均會被強迫轉為字串, 因此若原為null就被轉為空字串 同理 DataSet.fieldbyname(fieldname).asInteger原無值時就被轉為0了
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-12-19 11:40:09 IP:202.39.xxx.xxx 未訂閱
插個花, TField.IsNull 也可以判斷是否為 NULL --- Everything I say is a lie.
系統時間:2024-04-26 0:46:27
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!