Golang操作MySQL增删改查

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

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

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

查看所有标签

猜你喜欢:

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

Python Cookbook

Python Cookbook

Alex Martelli、Anna Ravenscroft、David Ascher / 高铁军 / 人民邮电出版社 / 2010-5-1 / 99.00元

本书介绍了Python应用在各个领域中的一些使用技巧和方法,从最基本的字符、文件序列、字典和排序,到进阶的面向对象编程、数据库和数据持久化、 XML处理和Web编程,再到比较高级和抽象的描述符、装饰器、元类、迭代器和生成器,均有涉及。书中还介绍了一些第三方包和库的使用,包括 Twisted、GIL、PyWin32等。本书覆盖了Python应用中的很多常见问题,并提出了通用的解决方案。书中的代码和方......一起来看看 《Python Cookbook》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换