使用 Golang 建立 RESTful API 並連接 MySQL 資料庫:安裝 Golang、MySQL 驅動程式和建立專案。定義 API 處理程序,包括取得所有使用者和特定使用者。透過 sql.Open 函數連接到 MySQL 資料庫。使用 db.Query 和 db.QueryRow 從資料庫中取得資料。使用 json.NewEncoder 編寫 JSON 回應。可選:提供建立新使用者的程式碼範例。
如何使用Golang 建立RESTful API 並連接MySQL 資料庫
##介紹
RESTful API 是一種基於HTTP 協定的API 類型,可簡化客戶端與伺服器之間的互動。使用 Golang 建立 RESTful API 可以充分利用其高效能和並發性優勢。本文將指導你如何使用 Golang 建立一個 RESTful API,並連接到 MySQL 資料庫。先決條件
)
建立RESTful API
指令建立新專案。
指令安裝 MySQL 驅動程式。
檔案中寫以下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)) }
函數連接到MySQL 資料庫。
函數定義兩個路由處理程序:
/users 和
/users/ :id。
函數啟動伺服器。
處理使用者請求
處理程序中,使用
db.Query 函數從資料庫中取得所有使用者。
處理程序中,使用
db.QueryRow 函數從資料庫中取得特定使用者。
函數將使用者資料編碼為 JSON 並寫入到 HTTP 回應中。
實戰案例
假設你的MySQL 資料庫中有一個名為users 的表,其架構如下:
CREATE TABLE users ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
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) }
注意:不要忘記更新資料庫連線資訊以及跨網域請求相關的處理機制。
以上是如何使用 Golang 建立 RESTful API 並連接 MySQL 資料庫?的詳細內容。更多資訊請關注PHP中文網其他相關文章!