Erstellen Sie eine RESTful-API und stellen Sie mit Golang eine Verbindung zur MySQL-Datenbank her: Installieren Sie Golang und den MySQL-Treiber und erstellen Sie ein Projekt. Definieren Sie API-Handler, einschließlich des Abrufens aller Benutzer und bestimmter Benutzer. Stellen Sie über die Funktion sql.Open eine Verbindung zur MySQL-Datenbank her. Verwenden Sie db.Query und db.QueryRow, um Daten aus der Datenbank abzurufen. Verwenden Sie json.NewEncoder, um JSON-Antworten zu schreiben. Optional: Stellen Sie Codebeispiele zum Erstellen neuer Benutzer bereit.
So verwenden Sie Golang, um eine RESTful-API zu erstellen und eine Verbindung zu einer MySQL-Datenbank herzustellen
Einführung
RESTful-API ist ein API-Typ, der auf dem HTTP-Protokoll basiert und die Interaktion zwischen dem Client und dem Server vereinfacht . Beim Erstellen von RESTful-APIs mit Golang werden dessen hohe Leistung und Parallelität voll ausgenutzt. In diesem Artikel erfahren Sie, wie Sie mit Golang eine RESTful-API erstellen und eine Verbindung zu einer MySQL-Datenbank herstellen.
Voraussetzungen
github.com/go-sql-driver/mysql
) github.com/go-sql-driver/mysql
)构建 RESTful API
go mod init <项目名称>
命令创建新项目。go get -u github.com/go-sql-driver/mysql
命令安装 MySQL 驱动程序。main.go
文件中编写以下 API 处理程序:package main import ( "database/sql" "log" "net/http" "strconv" "github.com/go-sql-driver/mysql" ) const ( user = "root" password = "" host = "localhost" port = 3306 database = "my_db" ) var db *sql.DB func init() { dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?parseTime=true", user, password, host, port, database) var err error db, err = sql.Open("mysql", dsn) if err != nil { log.Fatal(err) } } func main() { http.HandleFunc("/users", handleUsers) http.HandleFunc("/users/", handleUser) log.Fatal(http.ListenAndServe(":8080", nil)) }
sql.Open
函数连接到 MySQL 数据库。http.HandleFunc
函数定义两个路由处理程序:/users
和 /users/:id
。http.ListenAndServe
函数启动服务器。处理用户请求
/users
处理程序中,使用 db.Query
函数从数据库中获取所有用户。/users/:id
处理程序中,使用 db.QueryRow
函数从数据库中获取特定用户。json.NewEncoder
函数将用户数据编码为 JSON 并写入到 HTTP 响应中。实战案例
假设你的 MySQL 数据库中有名为 users
ul>
Erstellen Sie eine RESTful-API
go mod init <project name>
ein neues Projekt. 🎜🎜🎜Installieren Sie den MySQL-Treiber: 🎜Verwenden Sie den Befehl go get -u github.com/go-sql-driver/mysql
, um den MySQL-Treiber zu installieren. 🎜🎜🎜Schreiben Sie den API-Handler: 🎜Schreiben Sie den folgenden API-Handler in die Datei main.go
: 🎜CREATE TABLE users ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
sql.Open
, um eine Verbindung zur MySQL-Datenbank herzustellen. 🎜🎜🎜Routenhandler definieren: 🎜Verwenden Sie die Funktion http.HandleFunc
, um zwei Routenhandler zu definieren: /users
und /users/:id
. 🎜🎜🎜Führen Sie den Server aus: 🎜Verwenden Sie die Funktion http.ListenAndServe
, um den Server zu starten. 🎜/users
verwenden Sie zum Abrufen die Funktion db.Query
Alle Benutzer aus der Datenbank Alle Benutzer abrufen in . 🎜🎜🎜Einen bestimmten Benutzer abrufen: 🎜Im Handler /users/:id
verwenden Sie die Funktion db.QueryRow
, um einen bestimmten Benutzer aus der Datenbank abzurufen. 🎜🎜🎜Antwort schreiben: 🎜Verwenden Sie die Funktion json.NewEncoder
, um die Benutzerdaten in JSON zu kodieren und in die HTTP-Antwort zu schreiben. 🎜users
in Ihrer MySQL-Datenbank mit der folgenden Struktur: 🎜func handleCreateUser(w http.ResponseWriter, r *http.Request) { var user User if err := json.NewDecoder(r.Body).Decode(&user); err != nil { http.Error(w, "Invalid JSON", http.StatusBadRequest) return } stmt, err := db.Prepare("INSERT INTO users (name, email) VALUES (?, ?);") if err != nil { log.Fatal(err) } defer stmt.Close() res, err := stmt.Exec(user.Name, user.Email) if err != nil { log.Fatal(err) } id, err := res.LastInsertId() if err != nil { log.Fatal(err) } user.ID = int(id) json.NewEncoder(w).Encode(user) }
Das obige ist der detaillierte Inhalt vonWie verwende ich Golang, um eine RESTful-API zu erstellen und eine Verbindung zu einer MySQL-Datenbank herzustellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!