| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1657 人关注过本帖
标题:请问我写的这个自动生产编号的程序为什么会出问题
只看楼主 加入收藏
yflovevb01
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2017-4-28
结帖率:75%
收藏
已结贴  问题点数:10 回复次数:6 
请问我写的这个自动生产编号的程序为什么会出问题
Dim rs As New ADODB.Recordset
Dim cnn As New ADODB.Connection

Private Sub Command1_Click()
rs.Open "select * from guest order by 编号", cnn, adOpenKeyset, adLockOptimistic
If rs.RecordCount > 0 Then
rs.MoveLast
Text1.Text = Format(Val(rs.Fields("编号")) + 1, "00000")
Else
Text1.Text = "00001"
End If
rs.Close
End Sub

Private Sub Command2_Click()
rs.Open "ABC", cnn, adOpenKeyset, adLockOptimistic
rs.AddNew
rs!编号 = Text1.Text
rs.Update
rs.Close
MsgBox "保存成功!"
Unload Me
End Sub

Private Sub Form_Load()
cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\Store Findeway Management.mdb;Persist Security Info=False"
End Sub

以上是我写的代码
我需要实现的是自动编号
点一下command1
text1会自动生成编号
点command2
将会自动保存
我感觉没什么问题了
但是我生成的编号一直是00001
很无奈
求大神解释一下
搜索更多相关主题的帖子: 自动 编号 Sub Text1 End 
2017-05-04 16:11
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4947
专家分:30084
注 册:2008-10-15
收藏
得分:10 
Private Sub Command1_Click()
rs.Open "select max(编号) as M编 from guest", cnn, adOpenKeyset, adLockOptimistic        '直接返回一条记录,该记录显示 编号的最大值
'未测试数据库无记录时,是否也有记录返回
Text1.Text = Format(Val(rs.Fields("M编")) + 1, "00000")
rs.Close
End Sub

这样试试看。

授人于鱼,不如授人于渔
早已停用QQ了
2017-05-04 16:20
yflovevb01
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2017-4-28
收藏
得分:0 
还是一直都生成00001
2017-05-04 16:25
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4947
专家分:30084
注 册:2008-10-15
收藏
得分:0 
好吧,我建库来测试一下。

授人于鱼,不如授人于渔
早已停用QQ了
2017-05-04 17:34
yflovevb01
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2017-4-28
收藏
得分:0 
太感谢了
2017-05-04 17:38
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4947
专家分:30084
注 册:2008-10-15
收藏
得分:0 
测试结果,你的代码,我的代码都有效。
我的代码需要处理 无记录的情况。

程序代码:
Private Sub Command1_Click()
rs.Open "select max(编号) as M编 from guest", cnn, adOpenKeyset, adLockOptimistic        '直接返回一条记录,该记录显示 编号的最大值
'未测试数据库无记录时,是否也有记录返回
If IsNull(rs.Fields(0)) Then
  Text1.Text = "00001"
Else
  Text1.Text = Format(Val(rs.Fields(0)) + 1, "00000")
End If
rs.Close
End Sub


=================
你的错误出在,保存模块,你保存在哪个表??
而你读又在哪个表???
表都不一样,自然永远返回 00001 啊。


授人于鱼,不如授人于渔
早已停用QQ了
2017-05-04 17:43
yflovevb01
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2017-4-28
收藏
得分:0 
!!!!
好了!!
确实是这样
谢谢版主
请问我能加您的联系方式吗?
2017-05-04 18:06
快速回复:请问我写的这个自动生产编号的程序为什么会出问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017087 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved