IN-Klausel und Deklaration von Variablen in SQL Server: Typkonvertierungsfehler vermeiden
In einigen Fällen müssen Sie möglicherweise mehrere Werte in eine IN-Klausel aufnehmen, die durch deklarierte Variablen dargestellt werden. Diese Technik ermöglicht die zentrale Verwaltung dieser Werte innerhalb komplexer gespeicherter Prozeduren, sodass keine wiederholten Aktualisierungen erforderlich sind. Bei der Ausführung solcher Abfragen gibt es jedoch einige Herausforderungen.
Frage:
Der folgende Codeausschnitt zeigt ein Beispiel für dieses Problem:
<code class="language-sql">DECLARE @ExcludedList VARCHAR(MAX) SET @ExcludedList = '3,4,22' SELECT * FROM A WHERE Id NOT IN (@ExcludedList)</code>
Fehler: Die Konvertierung ist beim Konvertieren des Varchar-Werts in den Typ int fehlgeschlagen.
Fehlergrund:
Dieser Fehler tritt auf, weil die Abfrage versucht, eine Ganzzahlspalte (ID) mit einer Zeichenfolgenvariablen (@ExcludedList) zu vergleichen, die durch Kommas getrennte Werte enthält. Die IN-Klausel erwartet Ganzzahlen als Eingabe, während die deklarierten Variablen Zeichenfolgen enthalten.
Lösung:
Um diese Herausforderung zu meistern, sollten Sie die Verwendung von Tabellenvariablen anstelle der Deklaration von Variablen in Betracht ziehen. Tabellenvariablen können mehrere Werte dynamisch im Tabellenformat speichern, was ihre Verwendung in IN-Klauseln erleichtert.
<code class="language-sql">DECLARE @your_list TABLE (list INT) INSERT into @your_list (list) VALUES (3),(4),(22) SELECT * FROM A WHERE Id NOT IN (select list from @your_list)</code>
Durch die Verwendung von Tabellenvariablen vergleichen Abfragen jetzt ganze Zahlen genau mit ganzen Zahlen und beheben so Konvertierungsfehler.
Dieser Ansatz bietet mehr Flexibilität und Effizienz beim Umgang mit mehreren Werten in der IN-Klausel. Es ermöglicht die dynamische Befüllung der Liste und zentralisiert die Verwaltung dieser Werte an einem Ort, wodurch es einfacher wird, die Liste nach Bedarf zu aktualisieren oder zu ändern.
Das obige ist der detaillierte Inhalt vonSQL Server IN-Klausel mit Variablen: Wie vermeide ich Konvertierungsfehler?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!