RESTful API를 구축하고 Golang을 사용하여 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 데이터베이스에 연결하는 방법을 안내합니다.
전제 조건
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>
RESTful API 구축
go mod init ea05abe187ada2ae937559e33ea428f2
명령을 사용하여 새 프로젝트를 만듭니다. 🎜🎜🎜MySQL 드라이버 설치: 🎜go get -u github.com/go-sql-driver/mysql
명령을 사용하여 MySQL 드라이버를 설치합니다. 🎜🎜🎜API 핸들러 작성: 🎜main.go
파일에 다음 API 핸들러 작성: 🎜CREATE TABLE users ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
sql.Open
함수를 사용하여 MySQL 데이터베이스에 연결하세요. 🎜🎜🎜경로 핸들러 정의: 🎜http.HandleFunc
함수를 사용하여 두 개의 경로 핸들러인 /users
및 /users/:id
를 정의합니다. 🎜🎜🎜서버 실행: 🎜서버를 시작하려면 http.ListenAndServe
함수를 사용하세요. 🎜/users
핸들러에서 db.Query
함수를 사용하여 검색합니다. 데이터베이스의 모든 사용자 . 🎜🎜🎜특정 사용자 가져오기: 🎜/users/:id
핸들러에서 db.QueryRow
함수를 사용하여 데이터베이스에서 특정 사용자를 가져옵니다. 🎜🎜🎜응답 작성: 🎜json.NewEncoder
함수를 사용하여 사용자 데이터를 JSON으로 인코딩하고 이를 HTTP 응답에 씁니다. 🎜users
라는 테이블이 있다고 가정해 보겠습니다. 🎜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) }🎜다음 코드를 사용하여 새 사용자를 생성하고 데이터베이스에 추가하세요: 🎜rrreee🎜🎜참고: 🎜교차 도메인 요청과 관련된 데이터베이스 연결 정보 및 처리 메커니즘을 업데이트하는 것을 잊지 마세요. 🎜
위 내용은 RESTful API를 구축하고 Golang을 사용하여 MySQL 데이터베이스에 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!