完美解决零件库存月结修改窗体中防止重复的问题-fxs
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access开发平台


完美解决零件库存月结修改窗体中防止重复的问题

发表时间:2012/6/8 7:15:20 评论(0) 浏览(7095)  评论 | 加入收藏 | 复制
   
摘 要:众所周知,在开发中设计库存月结窗体时,因为同一时间的库存内容照理是不能够重复的,但变速箱教程中为了降低难度适应初学者,没有涉及限制重复的内容,但是,追求完美的我们怎么会容忍这种缺憾存在呢?
正 文:

众所周知,在开发中设计库存月结窗体时,因为同一时间的库存内容照理是不能够重复的,但变速箱教程中为了降低难度适应初学者,没有涉及限制重复的内容,但是,追求完美的我们怎么会容忍这种缺憾存在呢?

这种要求在“新增”窗体中并不难实现,但是,在“修改”窗体中实现就不那么容易了,因为修改窗体一打开就和原表中的数据重复,如果此时保存,肯定是重复的,所以实现起来有点困难。

迎难而上是我的特点,立马动手,说干就干,虽然有诸多难题,但是,经过网上的UMVsoft1老师(不知道名称对不对)的手把手指导(远程),终于完美解决了修改窗体的防止重复代码,成果不敢独享,特发上来大家给学习、修改、评论。

思路:

1、修改窗体采用非绑定表的方法;

2、建立临时表,通过查询把同一库存月份的数据追加到临时表中;

3、利用dcount函数判断重复,弹出提示框。

代码如下(零件库存月结):

Private Sub cmd_save()
    Dim rst As DAO.Recordset
    Dim strsql As String
    If IsNull(Me.ljid) Then
        MsgBox "请输入零件名称!", vbCritical, "提示:"
        Me.ljid.SetFocus
        Exit Sub
    End If
    If IsNull(Me.kcl) Then
        MsgBox "请输入库存量!", vbCritical, "提示:"
        Me.kcl.SetFocus
        Exit Sub
    End If
   
    Me.Refresh
    DoCmd.SetWarnings False
    DoCmd.RunSQL "Insert INTO tblljkcyj_temp ( ID, ljid, kcl, kcyf ) Select tblLjkcyj.ID, tblLjkcyj.ljid, tblLjkcyj.kcl, tblLjkcyj.kcyf FROM tblLjkcyj Where (tblLjkcyj.kcyf)=#" & Me.kcyf & "#;"

   Docmd.setwarnings true
    If DCount("ljid", "tblljkcyj_temp", "ljid='" & Me.ljid & "'") > 0 Then
        If DCount("kcl", "tblljkcyj_temp", "kcl=" & Me.kcl & "") > 0 Then
       
            MsgBox "同一库存月份的零件名称重复或您未做任何修改!", vbCritical, "警告!"
            Me.ljid.SetFocus
            Exit Sub
        End If
    End If
    strsql = "select* from tblljkcyj where id=" & numselectID & ""
    Set rst = CurrentDb.OpenRecordset(strsql, dbOpenDynaset)
    If MsgBox("您确认要保存吗?", vbYesNo + vbInformation, "提示”") = vbYes Then
        rst.Edit
        rst!ljid = Me.ljid
        rst!kcl = Me.kcl
        rst!kcyf = Me.kcyf
        rst.Update
        rst.Close
        Set rst = Nothing
    End If
    DoCmd.Echo False
    Forms!usysfrmmain!frmChild.SourceObject = "frmljkcyj_child"
    DoCmd.Echo True
    DoCmd.Close acForm, "frmljkcyj_child_edit"
End Sub

需要说明的几点:

1、每次打开和关闭修改窗体时,临时表要清空;

2、如果没有做任何修改就保存,会提示,但是如果修改零件或者库存量就不会提示了;

3、代码肯定不尽完美,请高手批评指正。


Access软件网交流QQ群(群号:198465573)
 
 相关文章
利用联合查询实现库存计算   【竹笛  2005/5/2】
库存余额和自定义库龄区段   【王志坚  2003/12/16】
库存数超出其上限、下限的报警   【王志坚  2004/4/16】
库存计算功能的实现示例   【UMVsoft整理  2007/6/15】
【access小品】美女彤彤的故事--仓库管理系统示例  【煮江品茶  2011/7/31】
论库存控制与数据准确性问题(转)  【e-works  2011/8/12】
《仓库进销存ERP管理系统》与《车间ERP管理系统》access学...  【邢金玲  2012/4/19】
Access条件格式应用示例\库存小于发货数量时记录整行变色,满足...  【风行  2012/8/18】
常见问答
技术分类
相关资源
文章搜索
关于作者

fxs

文章分类

文章存档

友情链接