Golang操作MySQL增删改查

小小程序员Eric · · 1788 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。


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


func main() {
    db, err := sql.Open("mysql", "root:0314@tcp(127.0.0.1:3306)/golang_test?charset=utf8")
    checkErr(err)
    defer db.Close()
    // insert(db)
    // query(db)
    // update(db)
    // delete(db)
}

// insert
func insert(db *sql.DB)  {
    stmt, err := db.Prepare("INSERT user (name, age) values (?,?)")
    checkErr(err)
    res, err := stmt.Exec("Eric", 22)
    checkErr(err)
    id, err := res.LastInsertId()
    checkErr(err)
    fmt.Printf("insert id=%d\n", id)
}

// query
func query(db *sql.DB)  {
    rows, err := db.Query("SELECT * FROM user")
    checkErr(err)
    // 列,字段名
    columns, err:= rows.Columns()
    checkErr(err)
    scanArgs := make([]interface{}, len(columns))
    values := make([]interface{}, len(columns))
    for i := range values {
        scanArgs[i] = &values[i]
    }
    for rows.Next() {
        err = rows.Scan(scanArgs...)
        checkErr(err)
        // 行,记录
        record := make(map[string]string)
        for i, col := range values {
            if col != nil {
                record[columns[i]] = string(col.([]byte))
            }
            fmt.Println(record)
        }
    }
}

// update
func update(db *sql.DB) {
    stmt, err := db.Prepare("UPDATE user SET name=?,age=? WHERE id=?")
    checkErr(err)
    res, err := stmt.Exec("Rose", 21, 1)
    checkErr(err)
    num, err := res.RowsAffected()
    fmt.Printf("affected:%d\n", num)
}

// delete
func delete(db *sql.DB) {
    stmt, err := db.Prepare("DELETE FROM user WHERE id=?")
    checkErr(err)
    res, err := stmt.Exec(1)
    checkErr(err)
    num, err := res.RowsAffected()
    fmt.Printf("affected:%d\n", num)
}

func checkErr(err error) {
    if err != nil {
        panic(err)
    }
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:小小程序员Eric

查看原文:Golang操作MySQL增删改查

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1788 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传