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

關於對TQuery取得其Schema中的預設值?

答題得分者是:Mickey
skurama
中階會員


發表:88
回覆:127
積分:73
註冊:2002-07-22

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-06-10 10:52:33 IP:61.219.xxx.xxx 未訂閱
請問: 目前小弟用的環境是 TQuery ODBC postgreSQL 7.3.2, 在利用 TQuery 新增資料時,如果有欄位沒有放入預設值時, 當存入資料庫後,沒放入預設值的欄為會是 NULL, 而目前公司的"(旺旺)先輩"們不希使用一個個欄位加入預設值, 也就是 Query1.fieldbyname('field1').AsString := ''; Query1.fieldbyname('field1').AsInteger := 0; 而大概只到Query1.Fields[1].DataType 可以取得欄位型態, Query1.Fields[1].FieldName 取得欄位名稱 但是 help 說Query1.Fields[1].DefaultExpression可以取得一個預設值 (HELP : Set DefaultExpression to provide a default value for a field) 可是我用showmessage(Query1.Fields[1].DefaultExpression)並沒有任何字串 以下是我想問的內容 1. 如何使用DefaultExpression? 2. 各位大大在使用 TQuery 新增資料時,是如何預防 NULl值的發生? ---------------- 快滿一年程設師, 日日工作寫程式, 每買樂透眼框溼, 望能早成系分師。 ----------------
------
----------------
初出芧房程設師,
左鍵右鼠寫程式,
日扣夜寫眼框溼,
望能早成系分師。
----------------
hagar
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-06-10 11:39:06 IP:202.39.xxx.xxx 未訂閱
1.更改 Table 的 Schema 的欄位的預設值 2.在 OnNewRecord 中設定欄位的預設值 3.設定 Table 欄位的 DefaultExpression 另看 help 中的第一個字是 Specifies 那 DefaultExpression 應該是用來設定的吧 不是用來取得 Table Schema 中欄位原先設定的預設值 奇怪的是, 不想一個一個指定預設值 為何不在 Schema 中設定, 一勞永逸呢?    --- 每個人都是一本書
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-06-10 11:42:01 IP:218.163.xxx.xxx 未訂閱
1. 資料庫端 create table 時, 即 with default.
   (如 : create table test (c1 varchar(5) default '123'))
2. TField.DefaultExpression property
   Specifies an SQL expression that is assigned to the field
   if the user does not provide a value. 
   你可能誤會該 property 的用法, 他是給你用來指定預設值, 而非讀出資料庫端之預設值設定.
skurama
中階會員


發表:88
回覆:127
積分:73
註冊:2002-07-22

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-06-10 11:56:33 IP:61.219.xxx.xxx 未訂閱
To 二位大大: 嗯~~我的確是有在Schema中加入預設值, 但是不知道為什麼用TQUery做Insert時, 如果沒有在前端把每個欄位的預設值放到Query中, 則最後資料沒有預設值的都是NULL 我是用 Delphi 7.0 PostgreSQL 的 ODBC 07.03.0100 PostgreSQL 7.3.2 ( OS 為 FreeBSD 4.7), 因為已經在Schema設定了預設值 create table table1 ( pk char(20) not NULL, field1 char(100) default '', field2 int4 default 0, primary key (pk)); 但是用TDataBase TQuery TUpdateSQL進行資料庫新增時, 結果發現沒有自己丟值進去的欄位都是NULL, 因為是用thrid party元件做edit等,以為是這些元件的問題, 但改為標準元件後,仍然是NULL。 而之後請朋友用interbase做資料庫,一樣是沒有打值的會是NULL。 所以我猜是TQUery的問題, 大家在用TQuery都不會遇到新增時,不要在前端給預設值時,會產生NULL的問題嗎? 我的語法大概如下 TQuery.Append; TQUery.fieldbyname('gk').AsString := 取得主鍵的function; TQuery.applyupdates; TQuery.commitupdates; 就這樣,資料庫內的值field1和field2都是NULL, 還是TQuery或 TUpdateSQL有屬性要調整? 麻煩各位大大了!! ---------------- 快滿一年程設師, 日日工作寫程式, 每買樂透眼框溼, 望能早成系分師。 ----------------
------
----------------
初出芧房程設師,
左鍵右鼠寫程式,
日扣夜寫眼框溼,
望能早成系分師。
----------------
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-06-10 13:47:18 IP:218.163.xxx.xxx 未訂閱
TUpdateSQL 會組合出 insert sql : insert into table1 (pk, field1, field2) values (xxx, null, null) 對 Database 來說, 如此的 statement 是會放棄 Default Value, 而會給 null value 到 field1, field 2 的. 1. 如果可以的話, 不要透過 TUpdateSQL 元件, 直接用 TQuery 去 ApplyUpdate. 2. Runtime (如 beforepost event ) 改變 TUpdateSQL.InsertSQL property, 未給值得欄位, 便無須放入(如 insert into table1 (pk) values (:pk)).
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-06-10 14:28:02 IP:203.95.xxx.xxx 未訂閱
這篇和在另一個論壇的這篇問題是一樣的, 請參考: http://forum.vclxx.org/topic.php?TOPIC_ID=26162&FORUM_ID=5&CAT_ID=2&Topic_Title=TQuery ·s¼W®É, ·| NULL&Forum_Title=Database
系統時間:2024-07-04 6:54:04
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!