你这种是属于不同类型使用同一种顺序号,按照下面方法处理,缺点是新增的行必须保存,否则下次获取还是会重复
Select e.DataCol.Name
Case "作业日期","工程"
If e.DataRow.IsNull("作业日期") OrElse e.DataRow.IsNull("工程") Then
e.DataRow("编号") = Nothing
Else
Dim fd As Date = Date.Today
Dim bh As String = e.DataRow("工程") & "-" & Format(fd,"yyyyMMdd") & "-" '生成编号的前缀
If e.DataRow("编号").StartsWith(bh) = False '如果编号前缀不符
Dim max As String
Dim idx As Integer
Dim flt As String
flt = "编号 like '" & bh & "%' And [_Identify] <> " & e.DataRow("_Identify")
max = e.DataTable.SQLCompute("Max(Mid(编号,len(编号) - 3,4))",flt) '取得该月的相同工程的最大编号
If max > "" Then '如果存在最大编号
idx = CInt(max) + 1
Else
idx = 1 '否则顺序号等于1
End If
If user.name = "1课"
e.DataRow("编号") = bh & "1" & Format(idx,"0000")
Else If user.name = "2课"
e.DataRow("编号") = bh & "2" & Format(idx,"0000")
Else If user.name = "开发者"
e.DataRow("编号") = bh & "0" & Format(idx,"0000")
End If
End If
End If
End Select