access新手來看:如何重復(fù)上一條記錄?

字號:

問題:
    如何重復(fù)上一條記錄?
    有一個窗體,上面有多個文本框和組合框,因為目錄這筆資料與下一筆資料大部門都是一樣的,能不能利用copy功能把上一筆的資料復(fù)制到下一筆的相對應(yīng)的文本框和組合框內(nèi).是做成按鈕式,即一個復(fù)制按鈕和一個粘貼按鈕。
    方法一:
    很多軟件里面都有這個功能?。?BR>    原理非常簡單。
    只要添加一個command BUTTON 就可以了。
    添加記錄的代碼相信大家都知道了。
     Private Sub Command16_Click()
    On Error GoTo Err_Command16_Click
     DoCmd.GoToRecord , , acNewRec
    exit_command16_click:
     Exit Sub
    err_command16_click:
     MsgBox Err.Description
     Resume Exit_Command16_Click
    End Sub
    我們更改一下即可,比如說現(xiàn)在有一個文本框,當(dāng)然了,實際情況你可以再加代碼,或者干脆用CONTROLS循環(huán)來做。
    Private Sub Command16_Click()
    On Error GoTo Err_Command16_Click
     dim strTemp as string
     strTemp=TextBox1.value
     '原理很簡單,先將控件值賦值給變量
     '然后在添加記錄后再將該變量值賦值給控件
     DoCmd.GoToRecord , , acNewRec
     TextBox1.value=strTemp
    Exit_Command16_Click:
     Exit Sub
    err_command16_click:
     MsgBox Err.Description
     Resume Exit_Command16_Click
    End Sub
    另外 Ctrl+'(單引號)可以復(fù)制上一條記錄同一字段內(nèi)容。
    方法二: 
    用controls循環(huán)的代碼如下:
    Private Sub AutoWriteRecord()
    '自適應(yīng)
    On Error GoTo Err_AutoWriteRecord
     Dim D '創(chuàng)建一個變量
     Set D = CreateObject("Scripting.Dictionary")
     Dim i As Long
     For i = 0 To Me.Controls.Count - 1
     If Me.Controls(i).ControlType = acTextBox _
     Or Me.Controls(i).ControlType = acComboBox _
     Or Me.Controls(i).ControlType = acListBox _
     Or Me.Controls(i).ControlType = acCheckBox _
     Or Me.Controls(i).ControlType = acOptionButton Then
     If Me.Controls(i).Name <> "編號" Then
     '自動編號字段不可寫,所以除外,可以用on error resume next 忽略
     D.Add Me.Controls(i).Name, Me.Controls(i).Value
     End If
     End If
     Next i
     '原理很簡單,先將控件值賦值給變量
     '然后在添加記錄后再將該變量值賦值給控件
     DoCmd.GoToRecord , , acNewRec
     Dim K
     K = D.keys
     For i = 0 To D.Count - 1
     Me.Controls(K(i)).Value = D(K(i))
     Next i
     Set D = Nothing
    Exit_AutoWriteRecord:
     Exit Sub
    err_autowriterecord:
     MsgBox Err.Description
     Resume Exit_AutoWriteRecord
    End Sub
     Private Sub AutoWriteRecord_1(strControlName As String)
    '人工定義控件名
    On Error GoTo Err_AutoWriteRecord
     Dim D '創(chuàng)建一個變量
     Set D = CreateObject("Scripting.Dictionary")
     Dim strSName() As String
     strSName = Split(strControlName, ";")
     Dim i As Long
     For i = 0 To UBound(strSName) - 1
     D.Add strSName(i), Me.Controls(strSName(i)).Value
     Next i
     '原理很簡單,先將控件值賦值給變量
     '然后在添加記錄后再將該變量值賦值給控件
     DoCmd.GoToRecord , , acNewRec
     For i = 0 To UBound(strSName) - 1
     Me.Controls(strSName(i)).Value = D(strSName(i))
     Next i
     Set D = Nothing
    Exit_AutoWriteRecord:
     Exit Sub
    err_autowriterecord:
     MsgBox Err.Description
     Resume Exit_AutoWriteRecord
    End Sub
    測試:
    Private Sub Command16_Click()
     'AutoWriteRecord
     AutoWriteRecord_1 "字段1;字段2;字段4;"
    End Sub