Heim >Backend-Entwicklung >Golang >Wie gehe ich mit „IN'-Klauseln mit Slices in Golang-Datenbankabfragen um: Fallstricke vermeiden?

Wie gehe ich mit „IN'-Klauseln mit Slices in Golang-Datenbankabfragen um: Fallstricke vermeiden?

Barbara Streisand
Barbara StreisandOriginal
2024-11-01 10:29:30971Durchsuche

How to Handle

Golang-Datenbankabfrage mit Slice-IN-Klausel: Die Herausforderungen verstehen

Beim Versuch, eine IN-Klausel mit einem Slice von Ganzzahlen in einem Golang zu verwenden Bei einer Datenbankabfrage kann es zu unerwartetem Verhalten kommen. Lassen Sie uns die Gründe dafür untersuchen und idiomatische Lösungen identifizieren.

Das Standard-Datenbank-/SQL-Paket verarbeitet IN-Klauseln nicht automatisch mit Slices. Stattdessen übersetzt es die Abfrage direkt in die Datenbank, wo die Bindevariable (?) ein einzelnes Argument darstellt. Dies kann zu Verwirrung führen, wenn Sie versuchen, eine variable Anzahl von Argumenten basierend auf der Länge des Slice einzubeziehen.

Zum Beispiel schlägt die folgende Abfrage fehl:

var levels = []int{4, 6, 7}
rows, err := db.Query("SELECT * FROM users WHERE level IN (?);", levels)

Um diese Einschränkung zu überwinden, müssen Sie können das SQLX-Paket nutzen, das eine bessere Kontrolle über Datenbankabfragen bietet. Durch Vorverarbeiten der Abfrage mit sqlx.In können Sie das Slice als Argument angeben:

var levels = []int{4, 6, 7}
query, args, err := sqlx.In("SELECT * FROM users WHERE level IN (?);", levels)

Jetzt wird die Abfrage so geändert, dass sie eine Anzahl von Bindevariablen enthält, die der Länge des Slice und Ihnen entspricht kann es erfolgreich ausführen.

Ein tieferes Verständnis der Verwendung von sqlx.In finden Sie in der Dokumentation bei Godoc. Dieser Ansatz bietet eine idiomatischere und flexiblere Möglichkeit, IN-Klauseln mit Slices in Golang-Datenbankabfragen zu verarbeiten.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit „IN'-Klauseln mit Slices in Golang-Datenbankabfragen um: Fallstricke vermeiden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn