dbgrid流水號寫入實體資料庫 |
缺席
|
chi120
一般會員 ![]() ![]() 發表:16 回覆:16 積分:6 註冊:2007-08-28 發送簡訊給我 |
DBGRID虛擬欄位的流水號,可以寫在OnCalcFields裡
if cdsdetail.State = dsInsert then cdsdetailrec.Value:=cdsdetail.RecordCount 1 else cdsdetailrec.Value:= cdsdetail.RecNo; 但如果要寫在OnNewRecord裡 上面的方式 cdsdetail.RecordCount 1 這樣寫的話,刪除資料時會有問題。流水號會重複。 請問各位大大,能不能有什麼方式,可以讓流水號不要重複,跳號沒關係
------
Aki..就算沒有明天 |
P.D.
版主 ![]() ![]() ![]() ![]() ![]() ![]() 發表:603 回覆:4038 積分:3874 註冊:2006-10-31 發送簡訊給我 |
1.建議從你使用的資料庫下手, 看看有沒有支援自動增號的欄位功能, 一般sql資料庫都有, paradox也有支援
2.如果不清楚, 那你就只能自己寫code去檢查已使用的編號到那裡, 然後手動填入最新號(這種方式有很多做法) 你想想看 (例如:檢查目前最大號, 填入最大號 1 或者另外用一個資料庫記錄己成功給予的最後一號, 之後由這個資料庫來累計號數等等...) ===================引 用 chi120 文 章=================== DBGRID虛擬欄位的流水號,可以寫在OnCalcFields裡 if cdsdetail.State = dsInsert then cdsdetailrec.Value:=cdsdetail.RecordCount 1 else cdsdetailrec.Value:= cdsdetail.RecNo; 但如果要寫在OnNewRecord裡 上面的方式 cdsdetail.RecordCount 1 這樣寫的話,刪除資料時會有問題。流水號會重複。 請問各位大大,能不能有什麼方式,可以讓流水號不要重複,跳號沒關係 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |