Heim  >  Artikel  >  Backend-Entwicklung  >  So schließen Sie PreparedStatement in Golang

So schließen Sie PreparedStatement in Golang

PHPz
PHPzOriginal
2023-04-11 09:14:34622Durchsuche

PreparedStatement-Objekte werden häufig in datenbankbezogenen Vorgängen in Golang verwendet. PreparedStatement dient der Optimierung von SQL-Anweisungen, die von der Anwendung an die Datenbank gesendet werden. Im Gegensatz zu Anweisungen werden vorbereitete Anweisungen beim Erstellen für einen bestimmten Typ kompiliert und nicht bei jeder Ausführung. Dieser Kompilierungsprozess kann die Effizienz der Abfrageausführung verbessern, ist außerdem sicherer und kann SQL-Injection-Angriffe vermeiden. Das rechtzeitige Schließen von PreparedStatement, wenn es nicht mehr benötigt wird, ist jedoch ein wichtiger Teil der Speicherverwaltung. In diesem Artikel wird erläutert, wie Sie PreparedStatement schließen.

1. Erstellung vorbereiteter Anweisungen

Das Erstellen von PreparedStatament erfolgt normalerweise über die db.Prepare-Methode. Die spezifische Verwendung ist wie folgt:

stmt, err := db.Prepare("select * from users where username = ?;")

In diesem Beispiel verwenden wir vorbereitete Anweisungen, um alle Benutzer in der Datenbank abzufragen, deren Benutzername gleich „?“ ist.

2. Ausführung vorbereiteter Anweisungen

Nachdem wir eine vorbereitete Anweisung erstellt haben, müssen wir die vorbereitete Anweisung ausführen. Die spezifische Verwendung ist wie folgt:

res, err := stmt.Exec("Jack")

In diesem Beispiel verwenden wir die zuvor erstellte vorbereitete Anweisung stmt, übergeben den Parameter „Jack“ und führen ihn über die Methode stmt.Exec aus. Wenn die vorbereitete Anweisung ausgeführt wird, werden alle „?“ durch tatsächliche Parameterwerte ersetzt und dann zur Abfrage an die Datenbank gesendet. Die Ergebnisse der Abfrage werden in den Ergebnistypdaten zurückgegeben. Zu diesem Zeitpunkt haben wir die Verwendung vorbereiteter Anweisungen abgeschlossen.

3. PreparedStatement schließen

Wenn PreparedStatement nicht mehr benötigt wird, müssen wir es schließen, um Ressourcen freizugeben. Es gibt zwei Möglichkeiten, PreparedStatement zu schließen. Methode eins besteht darin, stmt.Close() direkt aufzurufen, um es zu schließen. Der Code lautet wie folgt:

stmt.Close()

Methode zwei besteht darin, stmt auf Null zu setzen, was mehr ist Dieser Ansatz ist sicherheitsorientiert, da es in der Go-Sprache unsicher ist, ein bereits geschlossenes Objekt gewaltsam zu schließen. Die spezifische Verwendung ist wie folgt:

stmt = nil

Es ist erwähnenswert, dass beim Schließen von PreparedStatement das damit verbundene Ergebnis nicht automatisch geschlossen wird. Wenn wir PreparedStatement schließen, müssen wir daher Result schließen, um Speicherverluste zu vermeiden.

res.Close()

4. Umgang mit Speicherlecks

Bei der Verwendung vorbereiteter Anweisungen müssen Sie darauf achten, dass PreparedStatement und Result nicht manuell geschlossen werden.

In der tatsächlichen Entwicklung werden vorbereitete Anweisungen normalerweise in Funktionen erstellt, und Variablen werden automatisch freigegeben, wenn der Bereich beendet wird. Wenn der Entwickler PreparedStatement und Result nicht manuell schließt, wird der von ihnen belegte Speicher beim Beenden der Funktion nicht freigegeben, was zu einem Speicherverlust führt. Um Speicherlecks zu vermeiden, müssen wir PreparedStatement und Result daher manuell schließen, bevor die Funktion beendet wird.

func GetUser(username string) ([]User, error) {
    stmt, err := db.Prepare("select * from users where username = ?;")
    if err != nil {
        return nil, err
    }
    defer stmt.Close()

    res, err := stmt.Exec(username)
    if err != nil {
        return nil, err
    }
    defer res.Close()

    // 从res中获取数据并处理

    return users, nil
}

In diesem Beispiel haben wir PreparedStatement und Result manuell geschlossen, um sicherzustellen, dass der von diesen Objekten belegte Speicher korrekt freigegeben wird, wenn die Funktion beendet wird. Dieses Beispiel kann auf andere Datenbankoperationen angewendet werden.

Kurz gesagt, bei vorbereiteten Anweisungen müssen Sie daran denken, PreparedStatement und Result nach der Verwendung zu schließen, da sonst Speicherverluste auftreten. Es gibt zwei Möglichkeiten, PreparedStatement zu schließen, nämlich stmt.Close() aufzurufen oder stmt auf Null zu setzen. Es wird empfohlen, die zweite Methode zu verwenden.

Das obige ist der detaillierte Inhalt vonSo schließen Sie PreparedStatement in Golang. 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