欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

sql表中獲取最大流水號的問題

admin
2011年3月3日 16:54 本文熱度 4120
 

我以前都是用以下的方法獲得最大流水號,,以前一直以為不會有重復號,,,


n=SQLEXEC(con,"select MAX(idh) from ghk","mycur")
IF n < 1
  MESSAGEBOX( "失敗 !")
RETU
ENDIF
zd_idh=mycur.exp+1
n=SQLEXEC(con,"insert into ghk(idh) values (?zd_idh)")
IF n < 1
  MESSAGEBOX( "失敗 !")
RETU
ENDIF


但我今天看到了論壇上另外一個人發的有關這方面的帖子,,,所以我也對我的這段代碼有疑慮了,,因為有可能同時二個人獲得同樣的最大號,,這該怎么辦??


該文章在 2011/3/3 16:54:39 編輯過

全部評論5

admin
2011年3月3日 16:54
能否建多一個表,用來存放最大的單號,當需要新單號的時候先到該表取得下一單號的數字,再作加1處理,這樣即使上一個用戶的單未完成,下一個用戶訪問該的時候取得的是另外一個單號了。

該評論在 2011/3/3 16:54:49 編輯過
admin
2011年3月3日 16:55
不是這樣的問題,,我是讀取后馬下先把最大號寫入表中的,并不是一個單全部處理完再寫入,,主要是在讀取計算最大號而沒有寫入表的瞬間有可能剛好同時有幾個人在操作(雖然這種機率是很少很少),,就可能產生重復號了

該評論在 2011/3/3 16:55:02 編輯過
admin
2011年3月3日 16:55
啟動事務,鎖定SQL表在你寫入時,其它用戶不可讀寫該表。

該評論在 2011/3/3 16:55:29 編輯過
admin
2011年3月3日 16:55
=SQLSETPROP(nhandle,"Transactions" ,2)&&啟動事務 csql="select MAX(spid) as maxid from sp with (serializable)" &&取最號,并鎖其它用戶讀入 nResult=TABLEUPDATE(.T.,.T.,'cursp')&&提交 IF nResult=.t.&&成功 =SQLCOMMIT(nhandle) =MESSAGEBOX("保存商品登記成功!",64,'提示') ELSE =SQLROLLBACK(nhandle) =MESSAGEBOX("保存商品登記失敗!",16,'提示') ENDIF =SQLSETPROP(nhandle,"Transactions" ,1)&&結束事務

該評論在 2011/3/3 16:55:46 編輯過
admin
2011年3月3日 16:56
一、編號的過程應該由服務器來完成。 二、編號的字段應該是主鍵。 三、編號都是由事務來完成的。 四、如果簡單的單一表處理。直接編寫成函數,然后在表的INSERT 觸發器寫入該函數;如果是涉及多表復雜處理,可以編寫成存儲過程,然后直接調用該存儲過程,并傳遞相應的參數,處理全部由存儲過程操作。

該評論在 2011/3/3 16:56:25 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved