iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用 Golang 构建 RESTful API 并连接 MySQL 数据库?
  • 568
分享到

如何使用 Golang 构建 RESTful API 并连接 MySQL 数据库?

golangmysqlgit 2024-05-16 10:05:29 568人浏览 独家记忆
摘要

使用 golang 构建 restful api 并连接 Mysql 数据库:安装 Golang、mysql 驱动程序和创建项目。定义 api 处理程序,包括获取所有用户和特定用户。通过

使用 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 数据库。

先决条件

  • 安装 Golang(版本 1.18 或更高)
  • MySQL 数据库和 MySQL 驱动程序(GitHub.com/go-sql-driver/mysql)
  • 文本编辑器或 IDE(如 Visual Studio Code)

构建 RESTful API

  1. 创建新项目:使用 go mod init 命令创建新项目。
  2. 安装 MySQL 驱动程序:使用 go get -u github.com/go-sql-driver/mysql 命令安装 MySQL 驱动程序。
  3. 编写 API 处理程序:在 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))
}
  1. 连接到 MySQL 数据库:使用 sql.Open 函数连接到 MySQL 数据库。
  2. 定义路由处理程序:使用 http.HandleFunc 函数定义两个路由处理程序:/users 和 /users/:id。
  3. 运行服务器:使用 http.ListenAndServe 函数启动服务器。

处理用户请求

  1. 获取所有用户:在 /users 处理程序中,使用 db.Query 函数从数据库中获取所有用户。
  2. 获取特定用户:在 /users/:id 处理程序中,使用 db.QueryRow 函数从数据库中获取特定用户。
  3. 编写响应:使用 json.NewEncoder 函数将用户数据编码为 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 数据库?的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 如何使用 Golang 构建 RESTful API 并连接 MySQL 数据库?

本文链接: https://www.lsjlt.com/news/617593.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作