Maison >développement back-end >Golang >Comment utiliser Golang pour créer une API RESTful et se connecter à une base de données MySQL ?
Créez l'API RESTful et connectez-vous à la base de données MySQL à l'aide de Golang : installez Golang, le pilote MySQL et créez un projet. Définissez les gestionnaires d'API, notamment en obtenant tous les utilisateurs et des utilisateurs spécifiques. Connectez-vous à la base de données MySQL via la fonction sql.Open. Utilisez db.Query et db.QueryRow pour obtenir des données de la base de données. Utilisez json.NewEncoder pour écrire des réponses JSON. Facultatif : fournissez des exemples de code pour créer de nouveaux utilisateurs.
Comment utiliser Golang pour créer une API RESTful et se connecter à une base de données MySQL
Introduction
L'API RESTful est un type d'API basé sur le protocole HTTP qui simplifie l'interaction entre le client et le serveur . La création d'API RESTful à l'aide de Golang tire pleinement parti de ses hautes performances et de sa concurrence. Cet article vous expliquera comment utiliser Golang pour créer une API RESTful et vous connecter à une base de données MySQL.
Prérequis
github.com/go-sql-driver/mysql
) github.com/go-sql-driver/mysql
)构建 RESTful API
go mod init c6cfd8f96e637fcf5991d47203973718
命令创建新项目。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>
Créez une API RESTful
go mod init ea05abe187ada2ae937559e33ea428f2
. 🎜🎜🎜Installez le pilote MySQL : 🎜Utilisez la commande go get -u github.com/go-sql-driver/mysql
pour installer le pilote MySQL. 🎜🎜🎜Écrivez le gestionnaire d'API : 🎜Écrivez le gestionnaire d'API suivant dans le fichier 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
pour vous connecter à la base de données MySQL. 🎜🎜🎜Définissez les gestionnaires de route : 🎜Utilisez la fonction http.HandleFunc
pour définir deux gestionnaires de route : /users
et /users/:id
. 🎜🎜🎜Exécutez le serveur : 🎜Utilisez la fonction http.ListenAndServe
pour démarrer le serveur. 🎜/users
, utilisez la fonction db.Query
pour récupérer tous les utilisateurs de la base de données Obtenir tous les utilisateurs dans . 🎜🎜🎜Obtenir un utilisateur spécifique : 🎜Dans le gestionnaire /users/:id
, utilisez la fonction db.QueryRow
pour obtenir un utilisateur spécifique de la base de données. 🎜🎜🎜Écriture de la réponse : 🎜Utilisez la fonction json.NewEncoder
pour encoder les données utilisateur en JSON et les écrire dans la réponse HTTP. 🎜users
dans votre base de données MySQL avec la structure suivante : 🎜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) }🎜Vous pouvez utiliser le code suivant pour créer un nouvel utilisateur et ajoutez-le À la base de données : 🎜rrreee🎜🎜Remarque : 🎜N'oubliez pas de mettre à jour les informations de connexion à la base de données et le mécanisme de traitement lié aux requêtes inter-domaines. 🎜
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!