全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:794
推到 Plurk!
推到 Facebook!

請問在insert時,該如何讓值為空白時是NULL呢?

尚未結案
writeman
初階會員


發表:31
回覆:34
積分:28
註冊:2004-02-17

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-11-24 08:45:39 IP:61.70.xxx.xxx 未訂閱
bfield1:= trim(adoquery1.Fields.fieldS[0].AsString);
bfield2:= trim(adoquery1.Fields.fieldS[1].AsString);
bfield3:= trim(adoquery1.Fields.fieldS[2].AsString);    str:= '';
str:= 'INSERT INTO CUSPDATA(CMPY_ID, CUSP_ID, CHARGE_PERSON)VALUES(';
str:= str   inttostr(bfield1)   ',';
str:= str   inttostr(bfield2)   ',';
str:= str   ''''   bfield3   ''''   ');';
 
adoquery1.sql.text:= str;
adoquery1.exesql;    若是bfield3沒有值的話,我希望insert進CUSPDATA TABLE裡是一個NULL
如果用上面那樣的寫法,TABLE裡的值卻是空白
請問該如何讓值為空白時是NULL呢?    
Fishman
尊榮會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-11-24 09:51:58 IP:210.65.xxx.xxx 未訂閱
Hi writeman,    建議修改如下
  bfield1:= trim(adoquery1.Fields.fieldS[0].AsString);
  bfield2:= trim(adoquery1.Fields.fieldS[1].AsString);
  bfield3:= trim(adoquery1.Fields.fieldS[2].AsString);      str:= 'INSERT INTO CUSPDATA(CMPY_ID, CUSP_ID, CHARGE_PERSON)VALUES(';
  if bfield1 = '' then
      Str := Str   'NULL'   ','
  else
      str:= Str   bfield1   ',';
  if bfield2 = '' then
      Str := str   'NULL'   ','
  else
      str:= str   bfield2   ',';
  if bfield3 = '' then
      Str := str   'NULL'   ');'
  else
      str:= str   Quotedstr(bfield3)   ');';
  ADOQuery1.SQL.Text:= str;
  ADOQuery1.Exesql;
---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman
系統時間:2024-05-18 12:42:56
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!