Foxtable(狐表)用户栏目专家坐堂 → 网络环境下的复杂编号的问题


  共有3846人关注过本帖平板打印复制链接

主题:网络环境下的复杂编号的问题

帅哥哟,离线,有人找我吗?
643561836
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:171 积分:1392 威望:0 精华:0 注册:2013/2/1 10:00:00
网络环境下的复杂编号的问题  发帖心情 Post By:2013/11/6 13:43:00 [只看该作者]

 网络环境下的复杂编号中的多表编号 
帮助中的代码如下:

多表编号

上述的代码只是对一个订单表进行自动编号,如果一个项目中有多个表需要进行类似的编号,可以修改编号表的结构,包括三列,分别是:表名、前缀和顺序号,表名和前缀是字符型,顺序号是整数型。

所有需要自动编号的表的DataRowAdding事件代码依然为:

Static Index As Integer = 99999
e.
DataRow("编号") = Format(Date.Today(),"yyMM") & "-" & Index
Index = Index -
1

而BeforeSaveDataRow事件代码需要稍微调整一下,加上表名的条件:

Dim dr As DataRow = e.DataRow
Dim
pf As String
If
dr.RowState <> DataRowState.Added Then '如果不是新增行
Return
'那么返回
ElseIf
dr.IsNull("日期") Then '如果没有输入日期
e.Cancel = True '取消保存此行
MessageBox.Show("必须输入日期!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
Return
Else

pf
= Format(dr("日期"),"yyMM")
'否则获得编号的前缀,两位年,两位月
End If
Dim
cmd1 As New SQLCommand
Dim
cmd2 As New SQLCommand
Dim
Key As Integer
Dim
nm As String = e.DataTable.name
cmd1
.ConnectionName = "编号" '设置数据源名称
cmd2
.ConnectionName = "编号"
cmd1
.commandText = "Select Count(*) From [编号] Where [前缀] = '" & pf & "' And 表名 = '" & nm & "'"
If
cmd1.ExecuteScalar = 0 Then '如果编号表不存在前缀的行,那么增加一行
cmd1.commandtext = "Insert Into 编号 (表名, 前缀, 顺序号) Values('" & nm & "','" & pf & "',1)"
cmd1.ExecuteNonQuery
End If

cmd1
.commandText = "Select [顺序号] From [编号] Where [前缀] = '" & pf & "' And 表名 = '" & nm & "'"
Do

Key
= cmd1.ExecuteScalar()
'从后台获得顺序号
cmd2.commandText = "Update [编号] Set [顺序号] = " & (Key + 1) & " Where [顺序号] = " & Key & " And [前缀] = '" & pf & "' And 表名 = '" & nm & "'"
If
cmd2.ExecuteNonQuery() > 0 Then '更新顺序号
Exit Do
'更新成功则退出循环
End If
Loop

e
.DataRow("编号") = pf & "-" & Format(Key,"0000")





那个表名要用中括号吗,即[表名]


 回到顶部