以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  网络环境下的复杂编号(已解决)  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=185492)

--  作者:青丘狐
--  发布时间:2023/2/25 16:38: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 = "Selec t Count(*) From [编号] Where [前缀] = \'" & pf & "\' And 表名 = \'" & nm & "\'"
If
cmd1.ExecuteScalar = 0 Then \'如果编号表不存在前缀的行,那么增加一行
   
cmd1.commandtext = "Inser t Into 编号 (表名, 前缀, 顺序号) Values(\'" & nm & "\',\'" & pf & "\',1)"
   
cmd1.ExecuteNonQuery
End If

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

    Key
= cmd1.ExecuteScalar()
\'从后台获得顺序号
   
cmd2.commandText = "Updat e [编号] 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")

 

 

 


此主题相关图片如下:dh01.png
按此在新窗口浏览图片

 


 


此主题相关图片如下:dh02.png
按此在新窗口浏览图片

 

保存后,数据库里单号没有变啊

[此贴子已经被作者于2023/2/26 20:48:14编辑过]

--  作者:有点蓝
--  发布时间:2023/2/25 16:54:00
--  
BeforeSaveDataRow事件有没有触发?编号表存储了什么内容?
--  作者:青丘狐
--  发布时间:2023/2/25 17:07:00
--  

DataRowAdding

\'网络编号
Static Index As Integer = 99999
e.DataRow("合同ID") = "CG" & Format(Date.Today(), "yyMM") & "-" & Index
Index = Index - 1

 

AfterSaveDataRow

\'\'网络编号
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.C \'设置数据源名称
cmd2.C
cmd1.commandText = "Selec t Count(*) From [网络编号] Where [前缀] = \'" & pf & "\' And 表名 = \'" & nm & "\'"
If cmd1.ExecuteScalar = 0 Then \'如果编号表不存在前缀的行,那么增加一行
    cmd1.commandtext = "Inser t Into 网络编号 (表名, 前缀, 顺序号) Values(\'" & nm & "\',\'" & pf & "\',1)"
    cmd1.ExecuteNonQuery
End If
cmd1.commandText = "Selec t [顺序号] From [网络编号] Where [前缀] = \'" & pf & "\' And 表名 = \'" & nm & "\'"
Do
    Key = cmd1.ExecuteScalar() \'从后台获得顺序号
    cmd2.commandText = "U pdate [网络编号] Set [顺序号] = " & (Key + 1) & " Where [顺序号] = " & Key & " And [前缀] = \'" & pf & "\' And 表名 = \'" & nm & "\'"
    If cmd2.ExecuteNonQuery() > 0 Then \'更新顺序号
        Exit Do \'更新成功则退出循环
    End If
Loo p
e.DataRow("合同ID") ="CG" & pf & "-" & Format(Key, "0000")

 

 


图片点击可在新窗口打开查看此主题相关图片如下:bhb.png
图片点击可在新窗口打开查看

--  作者:青丘狐
--  发布时间:2023/2/25 17:09:00
--  
写错事件了
--  作者:青丘狐
--  发布时间:2023/2/25 17:49:00
--  


图片点击可在新窗口打开查看此主题相关图片如下:ht01.png
图片点击可在新窗口打开查看

图片点击可在新窗口打开查看此主题相关图片如下:ht02.png
图片点击可在新窗口打开查看

 

合同ID编号是个关联字段,怎样用代码写让父表子表同时保存正确的编号

[此贴子已经被作者于2023/2/25 17:52:21编辑过]

--  作者:有点蓝
--  发布时间:2023/2/26 19:37:00
--  
……
Do
    Key = cmd1.ExecuteScalar() \'从后台获得顺序号
    cmd2.commandText = "U pdate [网络编号] Set [顺序号] = " & (Key + 1) & " Where [顺序号] = " & Key & " And [前缀] = \'" & pf & "\' And 表名 = \'" & nm & "\'"
    If cmd2.ExecuteNonQuery() > 0 Then \'更新顺序号
        Exit Do \'更新成功则退出循环
    End If
Loo p
dim 更新前编号 as string = e.DataRow("合同ID")
e.DataRow("合同ID") ="CG" & pf & "-" & Format(Key, "0000")
datatables("明细表").replacefor("合同ID",e.DataRow("合同ID"),"合同ID=\'" & 更新前编号 & "\'")