Heim > Backend-Entwicklung > Golang > Wie führe ich eine Go-Datenbankabfrage mit einem Slice in der IN-Klausel aus?

Wie führe ich eine Go-Datenbankabfrage mit einem Slice in der IN-Klausel aus?

Mary-Kate Olsen
Freigeben: 2024-10-25 21:11:28
Original
543 Leute haben es durchsucht

How to Execute a Go Database Query with a Slice in the IN Clause?

Golang-Datenbankabfrage mithilfe der Slice-IN-Klausel: Ein umfassendes Verständnis

Frage:

Warum erfolgt die folgende Golang-Datenbankabfrage? Die Verwendung eines Segments von Ints in der IN-Klausel schlägt fehl:

<code class="go">inq := "6,7" //strings.Join(artIds, ",")
rows, err = db.Query("SELECT DISTINCT title FROM tags_for_articles LEFT JOIN tags ON tags.id = tags_for_articles.tag_id WHERE article_id IN (?)", inq)</code>
Nach dem Login kopieren

Antwort:

Das Problem tritt auf, weil das für die Abfrage verwendete Datenbank-/SQL-Paket die nicht überprüft Abfrage und übergibt die Argumente direkt an den Datenbanktreiber. Dies macht die Handhabung von Abfragen mit IN-Klauseln, die eine variable Anzahl von Argumenten enthalten, zu einer Herausforderung.

In der bereitgestellten Abfrage steht das ? Die Bindungsvariable entspricht einem einzelnen Argument, während die beabsichtigte Verwendung darin besteht, mehrere Argumente basierend auf der Länge der Slice-ArtIds zu binden. Der Treiber ist jedoch nicht in der Lage, dies korrekt zu verarbeiten.

Um dieses Problem zu beheben, wird empfohlen, das SQLX-Paket zu verwenden, das eine bessere Kontrolle über Datenbankabfragen bietet.

Lösung verwenden das sqlx-Paket:

<code class="go">var artIds = []int{6, 7}
query, args, err := sqlx.In("SELECT DISTINCT title FROM tags_for_articles LEFT JOIN tags ON tags.id = tags_for_articles.tag_id WHERE article_id IN (?);", artIds)</code>
Nach dem Login kopieren

Die sqlx.In-Funktion verarbeitet die Abfrage und generiert die entsprechenden Bindevariablen für den Ints-Slice, sodass die Abfrage erfolgreich ausgeführt werden kann.

Weitere Informationen zu diesem Thema finden Sie in der Godoc-Dokumentation für InQueries.

Das obige ist der detaillierte Inhalt vonWie führe ich eine Go-Datenbankabfrage mit einem Slice in der IN-Klausel aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage