Golang操作MySQL增删改查

作者: 小小程序员Eric | 来源:发表于2018-11-21 01:21 被阅读16次

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)
    }
}

相关文章

网友评论

    本文标题:Golang操作MySQL增删改查

    本文链接:https://www.haomeiwen.com/subject/ozafqqtx.html