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

dbgrid流水號寫入實體資料庫

缺席
chi120
一般會員


發表:16
回覆:16
積分:6
註冊:2007-08-28

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-09-13 08:54:07 IP:61.221.xxx.xxx 訂閱
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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-09-13 17:32:57 IP:61.67.xxx.xxx 未訂閱
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 這樣寫的話,刪除資料時會有問題。流水號會重複。
請問各位大大,能不能有什麼方式,可以讓流水號不要重複,跳號沒關係
系統時間:2024-05-04 14:07:05
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!