设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 883|回复: 1
打印 上一主题 下一主题

[与其它组件] [求助]双击自动产生编号

[复制链接]
跳转到指定楼层
1#
发表于 2006-8-23 18:16:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
有这样一个格式的编号,请问各位版主如何自动产生.LD06PE0575.

其中LD和PE是固定的,06是年份,0575是流水号,也就是说顺序下排0576,0577等等.

就是说双击后可以自动按前面的流水号自己产生,比如第一个是LD06PE0575.第二个就是LD06PE0576.

各位谢谢了,在此拜托了.

我的写法是,但是不对.ORDERNO是字段名,O-外贸订货单头是表名.

Dim cn1 As New ADODB.Connection
  Dim com As New ADODB.Command
  Dim rec1 As New ADODB.Recordset
  Dim strtemp, a, b As String
     DoCmd.GoToRecord , , acNewRec
     Set cn1 = CurrentProject.Connection
     Set com.ActiveConnection = cn1
     com.CommandText = "select max(ORDERNO) as ORDERNO  from [O-外贸订货单头]"
     Set rec1 = com.Execute
     strtemp = rec1("ORDERNO")
        strtemp = 'LD' + Right(Year(DATE), 2) +'PE'+ Right((Right(strtemp, 4) + 1), 4)
     Me.OrderNo = strtemp


[此贴子已经被作者于2006-8-24 7:36:26编辑过]

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
 楼主| 发表于 2006-8-30 22:15:00 | 只看该作者
     问题已解决,代码如下
     Dim cn1 As New ADODB.Connection
     Dim com As New ADODB.Command
     Dim strtemp As String
     Set cn1 = CurrentProject.Connection
     Set com.ActiveConnection = cn1
     If IsNull(Me.OrderNo) Then
     com.CommandText = "select 'LD'+right(year(getdate()),2)+'PI'+replicate('0',4-len(cast(cast(right(isnull(max(orderno),'0000'),4) as int) as nvarchar(4))))+cast(right(isnull(max(orderno),'0000'),4)+1 as nvarchar(4)) as orderno from [O-外贸订货单头] "
     Set rec1 = com.Execute
      Me.OrderNo = rec1("orderno")
     DoCmd.RunMacro ("save")
     Else
     Me.OrderNo.Locked = True
     End If
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-3 05:41 , Processed in 0.080037 second(s), 26 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表