Golang操作MySQL增删改查

栏目: Go · 发布时间: 6年前

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java语言精粹

Java语言精粹

Jim Waldo / 王江平 / 电子工业出版社 / 2011-6 / 39.00元

这是一本几乎只讲java优点的书。 Jim Waldo先生是原sun微系统公司实验室的杰出工程师,他亲历并参与了java从技术萌生、发展到崛起的整个过程。在这《java语言精粹》里,jim总结了他所认为的java语言及其环境的诸多精良部分,包括:类型系统、异常处理、包机制、垃圾回收、java虚拟机、javadoc、集合、远程方法调用和并发机制。另外,他还从开发者的角度分析了在java技术周围......一起来看看 《Java语言精粹》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具