Foxtable(狐表)用户栏目专家坐堂 → 请求帮助


  共有1371人关注过本帖树形打印复制链接

主题:请求帮助

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


加好友 发短信
等级:六尾狐 帖子:1495 积分:12175 威望:0 精华:0 注册:2013/3/19 16:41:00
请求帮助  发帖心情 Post By:2017/11/14 15:11:00 [只看该作者]

请老师们帮忙写一个“部门+年+三位数累加”的编号,谢谢!

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/11/14 15:17:00 [只看该作者]


 回到顶部
帅哥哟,离线,有人找我吗?
nxqtxwz
  3楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1495 积分:12175 威望:0 精华:0 注册:2013/3/19 16:41:00
  发帖心情 Post By:2017/11/14 15:53:00 [只看该作者]

我编程不行啊,怎么把例子中的“月”去掉,只要“年+三位数”。把“部门”加在最前面呢?登录是以部门登录的。


 回到顶部
帅哥哟,离线,有人找我吗?
nxqtxwz
  4楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:六尾狐 帖子:1495 积分:12175 威望:0 精华:0 注册:2013/3/19 16:41:00
  发帖心情 Post By:2017/11/14 15:59:00 [只看该作者]

是不是这样就行了?

 

Dim d As Date = Date.Today
Dim max As String
Dim idx As Integer
Dim flt As String
Dim bh As String = User.Name & Format(d,"yyyy")
flt = "编号 like '" & bh & "%'"
Output.Show(flt)
max = e.DataTable.Compute("Max(编号)",flt)
If max > "" Then '如果存在最大单据编号
    idx = CInt(max.Substring(max.Length-3,3)) + 1
Else
    idx = 1 '否则顺序号等于1
End If
e.DataRow("编号") = bh & Format(idx,"000")

Tables("出差记录").Sort = "[_Identify] desc"

[此贴子已经被作者于2017/11/14 15:59:40编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/11/14 16:58:00 [只看该作者]

DataRowAdded事件

 

Dim d As Date = Date.Today
Dim bh As String = User.Name & Format(d,"yyyy")
dim flt = "编号 like '" & bh & "%'"
dim max = e.DataTable.Compute("Max(编号)",flt)
dim idx = 1
If max > "" Then '如果存在最大单据编号
    idx = CInt(max.Substring(bh.length)) + 1
End If
e.DataRow("编号") = bh & Format(idx,"000")


 回到顶部