Heim  >  Artikel  >  Backend-Entwicklung  >  So führen Sie MySQL-Abfragen in Go mit festgelegten Variablen aus

So führen Sie MySQL-Abfragen in Go mit festgelegten Variablen aus

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-10-23 17:48:02355Durchsuche

How to Execute MySQL Queries in Go with Set Variables

Go MySQL-Abfragen mit SET-Variablen

Problem

Sie versuchen, eine MySQL-Abfrage in Go auszuführen, die Variablen festlegt, bevor die Abfrage ausgeführt wird. Wenn Sie die Abfrage jedoch über Go ausführen, tritt bei der SELECT-Anweisung ein Syntaxfehler auf.

Lösung

Die Lösung dieses Problems umfasst zwei Schritte:

  1. DSN konfigurieren:

    • Wenn Sie eine Verbindung zu Ihrer Datenbank herstellen, fügen Sie Ihrem DSN die folgenden Einstellungen hinzu: ...&multiStatements=true&interpolateParams=true
  2. Sortierung konvertieren:

    • Wenn Sie MySQL verwenden, stellen Sie sicher, dass Ihre Datenbank und Tabellen dieselbe Sortierung verwenden. Wenn nicht, konvertieren Sie sie in utf8mb4_general_ci.

Erklärung

DSN-Konfiguration:

Die multiStatements Mit dieser Einstellung können mehrere Anweisungen in einer einzigen Abfrage ausgeführt werden. Die Einstellung interpolateParams ermöglicht die Parameterinterpolation, wodurch Sie ? Platzhalter für Abfrageparameter.

Sortierungskonvertierung:

MySQL verfügt über mehrere Sortierungen, die bestimmen, wie Zeichen sortiert und verglichen werden. Wenn die Sortierung der Datenbank und der Tabellen nicht übereinstimmt, können beim Durchführen von Vergleichen Sortierungsfehler auftreten. Durch die Konvertierung in eine konsistente Sortierung wird dieses Problem behoben.

Durch diese Änderungen können Sie Ihre Abfrage erfolgreich in Go ausführen, während Sie zuvor Variablen festlegen.

Das obige ist der detaillierte Inhalt vonSo führen Sie MySQL-Abfragen in Go mit festgelegten Variablen aus. 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