Heim > Backend-Entwicklung > Golang > So führen Sie eine Datenbankabfrage in Golang durch

So führen Sie eine Datenbankabfrage in Golang durch

PHPz
Freigeben: 2023-04-18 09:44:43
Original
1858 Leute haben es durchsucht

Golang ist eine effiziente, schnelle und leistungsstarke Programmiersprache, die zum Erstellen verschiedener Anwendungen verwendet werden kann, insbesondere in der Webentwicklung. In Verbindung mit einer Datenbank bietet Golang einige leistungsstarke Tools, die Entwicklern bei der Bearbeitung von Datenbanken helfen. In diesem Artikel konzentrieren wir uns darauf, wie Golang Datenbankabfragen durchführt.

1. Golang-Datenbankabfrage

Es gibt zwei Hauptmethoden zum Abfragen der Datenbank in Golang: Eine besteht darin, das in der Standardbibliothek bereitgestellte Datenbank-/SQL-Paket zu verwenden, und die Andere sind die Verwendung von ORM-Frameworks wie GORM, XORM usw. Hier stellen wir vor, wie Sie das Datenbank-/SQL-Paket zum Abfragen verwenden.

database/sql ist ein Paket in der Golang-Standardbibliothek zum Betreiben relationaler Datenbanken. Verwenden Sie es, um eine Verbindung zur Datenbank herzustellen und Vorgänge wie Importieren, Einfügen, Aktualisieren und Löschen auszuführen. Bevor Sie Datenbank/SQL verwenden, müssen Sie den entsprechenden Datenbanktreiber installieren. Wenn Sie beispielsweise eine Verbindung zu MySQL herstellen möchten, müssen Sie den MySQL-Treiber installieren. Zu den häufig verwendeten Datenbanktreibern in Golang gehören: MySQL, SQLite, Postgres usw.

2. Golang stellt eine Verbindung zur Datenbank her

Bevor wir Datenbank/SQL zum Abfragen der Datenbank verwenden, müssen wir zunächst eine Verbindung zur Datenbank herstellen. Das Folgende ist ein Beispielcode für die Verbindung mit einer MySQL-Datenbank:

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/database_name?charset=utf8")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()
}
Nach dem Login kopieren

Darunter gibt die Funktion sql.Open() ein Datenbankobjekt db zurück, mit dem wir die Datenbank betreiben können. Beachten Sie außerdem, dass die Datenbank nach Abschluss des Datenbankvorgangs über das Schlüsselwort defer geschlossen werden muss.

3. Golang-Abfragedaten

Nach erfolgreicher Verbindung mit der Datenbank können wir SQL-Anweisungen über das Datenbankobjekt ausführen, um die Daten abzufragen. Das Folgende ist ein Beispielcode zum Abfragen eines Datenelements:

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

type User struct {
    Id       int
    Name     string
    Age      int
}

func main() {
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/database_name?charset=utf8")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    var (
        id       int
        name     string
        age      int
    )

    err = db.QueryRow("SELECT id, name, age FROM users WHERE id = ?", 1).Scan(&id, &name, &age)
    switch {
    case err == sql.ErrNoRows:
        fmt.Println("没有这条记录!")
    case err != nil:
        panic(err.Error())
    default:
        user := User{Id:id, Name:name, Age:age}
        fmt.Println(user)
    }
}
Nach dem Login kopieren

In diesem Beispielcode definieren wir eine Benutzerstruktur User und fragen die Daten mit der ID 1 in der Datenbank über die QueryRow()-Methode ab. Die QueryRow()-Methode führt eine Abfrage aus und scannt ihre Ergebnisse in eine Datenzeile. Hier verwenden wir die Scan()-Methode, um die Ergebnisse der Datenbankabfrage der von uns definierten Benutzerdatenstruktur zuzuordnen und schließlich die Daten auszugeben.

Ebenso können wir auch mehrere Datenzeilen abfragen. Das Folgende ist ein Beispielcode zum Abfragen mehrerer Datenzeilen:

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

type User struct {
    Id       int
    Name     string
    Age      int
}

func main() {
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/database_name?charset=utf8")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    rows, err := db.Query("SELECT id, name, age FROM users")
    if err != nil {
        panic(err.Error())
    }
    defer rows.Close()

    var users []User
    for rows.Next() {
        var user User
        err := rows.Scan(&user.Id, &user.Name, &user.Age)
        if err != nil {
            panic(err.Error())
        }
        users = append(users, user)
    }

    fmt.Println(users)
}
Nach dem Login kopieren

In diesem Beispielcode verwenden wir die Query()-Methode, um die Benutzertabelle in der Datenbank abzufragen und alles durch die for-Schleife zu durchsuchen und Next()-Methode Abfrageergebnisse. Innerhalb des Schleifenkörpers definieren wir eine Benutzerstruktur und ordnen die Datenbankabfrageergebnisse der Struktur über die Scan()-Methode zu. Abschließend speichern wir die Ergebnisse in einem Slice und geben das Slice aus.

4. Zusammenfassung

Anhand des obigen Beispielcodes können wir sehen, dass die Verwendung des Datenbank-/SQL-Pakets in Golang für Datenbankabfragen sehr praktisch und effizient ist. Wir können die Datenbank flexibel betreiben und verschiedene Datenabfrageanforderungen bearbeiten. Auf dieser Grundlage schneidet Golang in der Webentwicklung sehr gut ab. Um eine bessere Erfahrung zu erzielen, können wir uns natürlich auch dafür entscheiden, das ORM-Framework zum Betreiben der Datenbank zu verwenden.

Das obige ist der detaillierte Inhalt vonSo führen Sie eine Datenbankabfrage in Golang durch. 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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage