Verwendung von VBA-Parametern in verschiedenen Kontexten in Microsoft Access
Um Fehler zu vermeiden und Namen in einfachen Anführungszeichen effizient zu verarbeiten, ist es wichtig, Parameter in komplexen Access-Anwendungen mit dynamischem SQL und Zeichenfolgenverkettung zu verwenden. Hier sind verschiedene Möglichkeiten, Parameter in unterschiedlichen Kontexten zu verwenden:
Formulare und Berichte
Access bietet die einzigartige Möglichkeit, die Werte von Steuerelementen in Formularen und Berichten direkt im SQL-Code zu verwenden, in vielen Fällen ohne Parameter. Für Steuerelemente verwenden Sie die Syntax Forms!MyForm!MyTextbox; für Steuerelemente in Unterformularen verwenden Sie Forms!MyForm!MySubform.Form!MyTextbox; für Steuerelemente in Berichten verwenden Sie Reports!MyReport!MyTextbox.
Domain-Aggregation
Domain-Aggregationen wie DLookUp können auch direkt von Formularen und Berichten profitieren. Zum Beispiel DLookUp("Field1", "Table2", "ID = Forms!MyForm!MyTextbox").
DoCmd.RunSQL
Wenn Sie DoCmd.RunSQL zum Ausführen eines SQL-Befehls verwenden, verwenden Sie die Zeichenfolgenverkettung, um Parameterwerte zusammenzuführen: DoCmd.RunSQL "INSERT INTO Table1(Field1) SELECT Field1 FROM Table2 WHERE ID =" & Me.MyTextbox.
DAO-Datensatzsatz
Für DAO verwenden Sie CurrentDb.CreateQueryDef(), um die Abfrage zu erstellen, und verwenden Sie dann QueryDef.Parameters, um die Parameter festzulegen:
<code class="language-vba">With CurrentDb.CreateQueryDef("", "INSERT INTO Table1(Field1) SELECT Field1 FROM Table2 WHERE Field1 = ? And Field2 = ?") .Parameters(0) = Me.Field1 .Parameters(1) = Me.Field2 .Execute End With</code>
ADODB-Eintragssatz
Verwenden Sie in ADO das ADODB.Command-Objekt und seine Parameters-Auflistung, um Parameter festzulegen. Übergeben Sie für unbenannte Parameter ein Wertearray an Command.Execute. Für benannte Parameter (obwohl nicht offiziell unterstützt) verwenden Sie Command.CreateParameter():
<code class="language-vba">With cmd Set .ActiveConnection = CurrentProject.Connection ' 使用当前数据库的连接 .CommandText = "INSERT INTO Table1(Field1) SELECT Field1 FROM Table2 WHERE Field1 = ? And Field2 = ?" .Parameters.Append .CreateParameter(, adVarWChar, adParamInput, Len(Me.Field1), Me.Field1) ' adVarWChar 用于可能包含 Unicode 的文本框 .Parameters.Append .CreateParameter(, adInteger, adParamInput, 8, Me.Field2) ' adInteger 用于整数(长整数或整数) .Execute End With</code>
TempVars
TempVars sind global verfügbare Variablen, die in mehreren Abfragen festgelegt und wiederverwendet werden können:
<code class="language-vba">TempVars!MyTempVar = Me.MyTextbox.Value ' 对简单的控件使用 .Value DoCmd.RunSQL "INSERT INTO Table1(Field1) SELECT Field1 FROM Table2 WHERE ID = TempVars!MyTempVar"</code>
Benutzerdefinierte Funktion (UDF)
Erstellen Sie eine Funktion mit statischen Variablen zum Speichern und Abrufen von Parameterwerten:
<code class="language-vba">Option Compare Database Option Explicit Private ThisDate As Date Public Function GetThisDate() As Date If ThisDate = #12:00:00 AM# Then ' 设置默认值。 ThisDate = Date End If GetThisDate = ThisDate End Function Public Function SetThisDate(ByVal NewDate As Date) As Date ThisDate = NewDate SetThisDate = ThisDate End Function</code>
Dann so verwenden:
<code class="language-vba">SetThisDate SomeDateValue ' 将 SomeDateValue 存储在 ThisDate 中。 DoCmd.RunSQL "INSERT INTO Table1(Field1) SELECT Field1 FROM Table2 WHERE [SomeDateField] = GetThisDate()"</code>
Das obige ist der detaillierte Inhalt vonWie können Parameter in VBA für Microsoft Access-Anwendungen effektiv verwendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!