| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1559 人关注过本帖, 1 人收藏
标题:关于vb和access保存数据不重复的问题
只看楼主 加入收藏
lucwd
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2017-5-4
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:5 
关于vb和access保存数据不重复的问题
我想按站名和系统来判断 都重复的话报数据存在否则保存成功,但是运行的时候没有效果,而且在access中把数据行删了,在运行VB保存,access中的id不从1开始计数,按照之前的序号开始计数
Private Sub Command1_Click()
Dim cnn As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim sql As String
cnn.Open "Driver={Microsoft Access Driver (*.mdb)};DBQ=" & App.Path & "\SJ.mdb"
rs.Open "select * from 表1 where 站名='combo1.Text ' and 系统= 'Combo2.Text'", cnn, adOpenStatic, adLockOptimistic
If rs.RecordCount <> 1 Then
MsgBox "数据已存在"
Else
rs.AddNew
rs.Fields("站名") = Combo1.Text
rs.Fields("系统") = Combo2.Text
rs.Fields("设备") = Combo3.Text
rs.Fields("清扫周期") = Text1.Text
rs.Fields("本次清扫日期") = DTPicker1
rs.Fields("清扫有效期") = Text3.Text
rs.Update
MsgBox "保存成功"
rs.Close
End If
End Sub
搜索更多相关主题的帖子: access 保存 数据 Text Fields 
2017-05-18 16:18
xiangyue0510
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:86
帖 子:938
专家分:5244
注 册:2015-8-10
收藏
得分:0 
rs.Open "select * from 表1 where 站名='combo1.Text ' and 系统= 'Combo2.Text'"
谁告诉你字符串可以操作的??
2017-05-18 17:24
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:2 
好像有命令重置自动计数器的,忘了怎么写了,求助百度应该可以找到(没百度我好像一句代码都不会写了),手工操作可以选择“数据库工具---压缩和修复数据库”,即可重置id

rs.Open "select * from 表1 where 站名='" & combo1.Text & "' and 系统= '" & Combo2.Text & '", cnn, adOpenStatic, adLockOptimistic
if rs.eof and rs.bof then
rs.AddNew
rs.Fields("站名") = Combo1.Text
rs.Fields("系统") = Combo2.Text
rs.Fields("设备") = Combo3.Text
rs.Fields("清扫周期") = Text1.Text
rs.Fields("本次清扫日期") = DTPicker1
rs.Fields("清扫有效期") = Text3.Text
rs.Update
MsgBox "保存成功"
....
2017-05-18 19:10
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
收藏
得分:18 
access中的id不从1开始计数,按照之前的序号开始计数   这个问题是所有数据库自动编号字段的特征引起的,用VB程序好像无能无力,只有删除自动编号字段,再重新创建这个字段
你的程序中有些问题,给你修改了一下,供参考:
cnn.Open "Driver={Microsoft Access Driver (*.mdb)};DBQ=" & App.Path & "\SJ.mdb"
rs.Open "select * from 表1 where  站名='" & combo1.Text & "' and 系统= '" & Combo2.Text & "'", cnn, adOpenStatic, adLockOptimistic
If rs.RecordCount > 0 Then
MsgBox "数据已存在"
Else
rs.AddNew
rs.Fields("站名") = Combo1.Text
rs.Fields("系统") = Combo2.Text
rs.Fields("设备") = Combo3.Text
rs.Fields("清扫周期") = Text1.Text
rs.Fields("本次清扫日期") = DTPicker1
rs.Fields("清扫有效期") = Text3.Text
rs.Update
MsgBox "保存成功"
End If
rs.Close
cnn.Close


[此贴子已经被作者于2017-5-18 21:08编辑过]


请不要选我!!!
2017-05-18 21:03
lucwd
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2017-5-4
收藏
得分:0 
回复 4楼 ZHRXJR
谢谢版主,用了您改的代码后,成功了。
2017-05-19 10:11
lucwd
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2017-5-4
收藏
得分:0 
谢谢大家
2017-05-19 10:11
快速回复:关于vb和access保存数据不重复的问题
数据加载中...
 
   



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

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