Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 窗体  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702059
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何任意记录上进行编辑,然后保存成一条新的记录,同时原记录没有发生改变

作者:cg1  摘自:access911.net  :cg1  更新日期:2005-10-24  浏览人次:

 

问题:

我在一个ACCESS程序的数据窗口中,首先在窗口中的字段文本框中修改了字段值,然后想通过如下代码在当前的表中新增一条记录:

        DoCmd.RunCommand acCmdSelectRecord    '选择当前记录
        DoCmd.RunCommand acCmdCopy            '复制当前记录
        DoCmd.RunCommand acCmdPasteAppend     '追加记录

但是发现acCmdCopy其实并不是复制当前记录,而是复制当前选择的文本框内容,所以要出错,不知道如何解决?应该是什么DoCmd.RunCommand acCmd********?
如果直接用DoCmd.RunCommand acCmdSaveRecord,就直接覆盖当前记录了,不是我想要的。
我是想在任意记录上进行编辑,然后保存成一条新的记录,同时原记录没有发生改变。

 


回答:


客户的要求往往非常怪异
http://access911.net/down/eg/save_Current_Edit_In_New_Record.rar
 (25KB)
仍旧是有多种方法


Private Sub Command4_Click()
    Dim strA As String
    strA = Me.FIELD1.Value
    If Me.Dirty = True And Me.NewRecord = False Then
        DoCmd.RunCommand acCmdUndo
    End If
    DoCmd.GoToRecord , , acNewRec
    Me.FIELD1.Value = strA
End Sub

Private Sub Command5_Click()
    If Me.Dirty = True And Me.NewRecord = False Then
        DoCmd.RunCommand acCmdSelectRecord    '选择当前记录
        DoCmd.RunCommand acCmdCopy            '复制当前记录
        DoCmd.RunCommand acCmdUndo
        DoCmd.RunCommand acCmdPasteAppend     '追加记录
    End If

End Sub


 


本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     如何不让窗体转入下一个新记录?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利