以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- [求助] (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=121081) |
-- 作者:沪上游客 -- 发布时间:2018/6/28 18:57:00 -- [求助] 老师您好! 我的表是SQL外部表,每增加一条记录,在保存当前行时会生成一个记录编号,但是今天出现了两条一样记录编号。不知道怎么会事?请老师指教一下或者有比这个更好的办法。谢谢! 以下是表BeforeSaveDataRow事件代码: If e.DataRow.IsNull("记录编号") Then If e.DataRow.IsNull("录入日期") Then e.DataRow("记录编号") = Nothing Else Dim bh As String = Format(e.DataRow("录入日期"),"yyyyMMdd") \'取得编号的8位前缀 If e.DataRow("记录编号").StartsWith(bh) = False \'如果编号的前8位不符 Dim max As String Dim idx As Integer max = e.DataTable.sqlCompute("Max(记录编号)","录入日期 = \'" & e.DataRow("录入日期") & "\' And [_Identify] <> " & e.DataRow("_Identify")) \'取得该天的最大编号 If max > "" Then \'如果存在最大编号 idx = CInt(max.Substring(12,3)) + 1 \'获得最大编号的后三位顺序号,并加1 Else idx = 1 \'否则顺序号等于1 End If e.DataRow("记录编号") = "YSK" & bh & "-" & Format(idx,"000") End If End If End If |
-- 作者:沪上游客 -- 发布时间:2018/6/28 19:06:00 -- 以前我这些代码写入表的DataColChanged事件中,因为出现了同样的问题,因为当有两个人同时新建记录,会出现两条相同的编号,因为没有保存,数据库中的记录最大数没有变化。我明白后把他改到BeforeSaveDataRow表事件中,现在还是出现了这个问题。没有这么巧两个同时保存吧? [此贴子已经被作者于2018/6/28 19:06:09编辑过]
|
-- 作者:有点甜 -- 发布时间:2018/6/28 19:43:00 -- 修改编号以后,save一下,代码还是要写到datacolchanged事件
e.DataRow("记录编号") = "YSK" & bh & "-" & Format(idx,"000") e.DataRow.Save |