Mehrere SQL-Anweisungen in einem String mit Go
In PHP ist es einfach, mehrere SQL-Anweisungen auf einmal auszuführen, indem man sie durch a trennt Semikolon. Allerdings kann es eine Herausforderung sein, einen MySQL-Treiber für Go zu finden, der diese Funktionalität bietet.
Ein beliebter Treiber, github.com/go-sql-driver/mysql, hatte diesbezüglich zunächst Einschränkungen. Aber gemäß der Dokumentation unterstützt es jetzt mehrere Anweisungen über den Verbindungsparameter multiStatements=true.
Hier ist ein geänderter Codeausschnitt zur Veranschaulichung:
package main import ( "database/sql" "fmt" "log" _ "github.com/go-sql-driver/mysql" ) func main() { // Create a connection string with multiStatements enabled connectionString := fmt.Sprintf("user:password@(127.0.0.1:3306)/?multiStatements=true") db, err := sql.Open("mysql", connectionString) if err != nil { log.Println(err) } sql := "DROP SCHEMA IF EXISTS foo; CREATE SCHEMA IF NOT EXISTS foo;" _, err = db.Exec(sql) if err != nil { log.Println(err) } db.Close() }
Mit dieser Änderung werden mehrere SQL-Anweisungen in Die SQL-Zeichenfolge wird in einem einzigen Aufruf ausgeführt, wodurch der zuvor aufgetretene „Fehler 1064“ beseitigt wird.
Denken Sie daran, dass Sie mehrere Anweisungen verwenden in einer Zeichenfolge sollte mit Vorsicht angegangen werden, da dies zu unvorhersehbaren Ergebnissen führen kann. Die offizielle Dokumentation von github.com/go-sql-driver/mysql bietet weitere Details zu diesem Thema.
Das obige ist der detaillierte Inhalt vonWie kann ich mit dem Treiber „github.com/go-sql-driver/mysql' von Go mehrere SQL-Anweisungen in einer einzelnen Zeichenfolge ausführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!