有關於SQL中的Not Null |
尚未結案
|
ship88
一般會員 發表:7 回覆:7 積分:2 註冊:2004-02-27 發送簡訊給我 |
|
timhuang
尊榮會員 發表:78 回覆:1815 積分:1608 註冊:2002-07-15 發送簡訊給我 |
Hi, 若是使用 TUpdateSQL 元件的話, 很容易做到這點, 在該元件的 InsertSQL 中有關該欄位的值拿掉即可, 如原來內容為, default 0 的欄位為 fsig 時, InsertSQL 內容如, Insert into mytable (fid, ftype, fsig) values (:fid, :ftype, :fsig) 改為 Insert into mytable (fid, ftype) values (:fid, :ftype) 如此一來便會以 table 的 default 來進行新增的動作, 當然, 若是不是用 TUpdateSQL 元件進行 batch 寫入時, 或是使用者在新增時可以在該欄位寫值時, 也可以在 BeforePost 事件中來判斷該欄位是否為 null , 若是為 null 的話, 給定預設值即可, 但要注意的是, 該預設值便會在程式裡, 而非由 table 的 default value 來控制囉, 如,
procedure TForm1.Query1BeforePost(DataSet: TDataSet); begin if DataSet.FieldByName('fsig').IsNull then begin DataSet.FieldByName('fsig').AsInteger := 0; end; end; |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |