Beim Versuch, OPENROWSET-Abfragen zu verwenden, die Variablen enthalten, stoßen viele Personen auf einen häufigen Fehler mit „falscher Syntax in der Nähe von „“. Um dieses Problem zu lösen, ist es unbedingt erforderlich, die Einschränkungen zu verstehen, die mit Variablen in OPENROWSET-Abfragen verbunden sind.
Im Gegensatz zu anderen Datenbankfunktionen erlaubt OPENROWSET nicht die direkte Einbeziehung von Ausdrücken oder Variablen in seine Argumente. Dies bedeutet, dass Sie die OPENROWSET-Anweisung nicht dynamisch mithilfe von Variablen erstellen können.
Um diese Einschränkung zu umgehen, besteht eine geeignete Strategie darin, einen dynamischen SQL-String zu erstellen, der die OPENROWSET-Anweisung dynamisch erstellt. Dieser String kann dann mit der EXEC-Anweisung ausgeführt werden. Hier ist eine Illustration:
Declare @ID int Declare @sql nvarchar(max) Set @ID=1 Set @sql='SELECT * FROM OPENROWSET( ''SQLNCLI'', ''DRIVER={SQL Server};'', ''EXEC dbo.usp_SO @ID =' + convert(varchar(10),@ID) + ''')' -- Print @sql Exec(@sql)
In diesem Beispiel wird eine dynamische SQL-Zeichenfolge „@sql“ basierend auf dem bereitgestellten Parameter „@ID“ erstellt. Anschließend führt die EXEC-Anweisung diese dynamische SQL-Zeichenfolge aus, wodurch effektiv die gewünschte OPENROWSET-Abfrage mit dem angegebenen Parameterwert ausgeführt wird.
Das obige ist der detaillierte Inhalt vonWie gehe ich mit dynamischen Parametern in OPENROWSET-Abfragen um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!