首頁 > 後端開發 > Golang > golang簡單實作mysql

golang簡單實作mysql

WBOY
發布: 2023-05-15 11:45:07
原創
803 人瀏覽過

使用 Golang 編寫程式來操作資料庫非常簡便,這一點在 MySQL 資料庫中也不例外。以下將為大家介紹 Golang 簡單實作 MySQL 操作的方法。

首先,確保你已經正確安裝了 Golang 和 MySQL,同時也需要安裝 Go 的 MySQL 驅動程式。這可以透過以下命令輕鬆完成:

go get -u github.com/go-sql-driver/mysql
登入後複製

在創建 Go 程式之前,我們還需要建立一個 MySQL 資料庫以及一張表來示範使用 Golang 進行資料庫操作的方法。

假設我們已經建立了一個名為 "test_db" 的資料庫,並且其中包含一張名為 "users" 的表。表的結構如下:

CREATE TABLE IF NOT EXISTS `users` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) NOT NULL,
  `email` varchar(50) NOT NULL,
  `age` smallint(6) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
登入後複製

接下來,我們就可以開始寫 Golang 程式了。以下是一個簡單的程式範例,展示如何使用Golang 驅動程式來連接MySQL 資料庫,並執行一些基本的查詢操作:

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // 连接 MySQL 数据库
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    // 执行查询操作
    rows, err := db.Query("SELECT * FROM users")
    if err != nil {
        panic(err.Error())
    }
    defer rows.Close()

    // 遍历查询结果
    for rows.Next() {
        var id int
        var name string
        var email string
        var age int
        err := rows.Scan(&id, &name, &email, &age)
        if err != nil {
            panic(err.Error())
        }
        fmt.Println(id, name, email, age)
    }

    // 检查是否存在错误
    err = rows.Err()
    if err != nil {
        panic(err.Error())
    }
}
登入後複製

透過執行以上程序,我們可以成功連接MySQL 資料庫,並使用" SELECT" 語句查詢"users" 表中的所有記錄,並將結果列印輸出。

除了查詢外,我們還可以使用 Golang 驅動程式來執行其他常見的 MySQL 操作,如插入、更新和刪除等。以下是一個簡單的程式範例:

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // 连接 MySQL 数据库
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    // 插入一条记录
    stmt, err := db.Prepare("INSERT INTO users(name, email, age) VALUES(?, ?, ?)")
    if err != nil {
        panic(err.Error())
    }
    defer stmt.Close()

    result, err := stmt.Exec("Tom", "tom@email.com", 30)
    if err != nil {
        panic(err.Error())
    }
    lastInsertId, _ := result.LastInsertId()
    fmt.Println("新增记录的 ID:", lastInsertId)

    // 更新一条记录
    stmt, err = db.Prepare("UPDATE users SET name=?, age=? WHERE id=?")
    if err != nil {
        panic(err.Error())
    }
    defer stmt.Close()

    result, err = stmt.Exec("Jerry", 25, 1)
    if err != nil {
        panic(err.Error())
    }
    affectRow, _ := result.RowsAffected()
    fmt.Println("受影响的行数:", affectRow)

    // 删除一条记录
    stmt, err = db.Prepare("DELETE FROM users WHERE id=?")
    if err != nil {
        panic(err.Error())
    }
    defer stmt.Close()

    result, err = stmt.Exec(1)
    if err != nil {
        panic(err.Error())
    }
    affectRow, _ = result.RowsAffected()
    fmt.Println("受影响的行数:", affectRow)
}
登入後複製

透過以上程式範例,我們可以成功執行插入、更新和刪除等常見 MySQL 操作。

整體來說,使用 Golang 驅動程式實作 MySQL 資料庫操作非常簡單。無論是查詢、插入、更新或刪除等各種操作,都可以透過 Golang 驅動程式輕鬆實現。

以上是golang簡單實作mysql的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板