美文网首页
Mysql操作

Mysql操作

作者: dayeshisir | 来源:发表于2019-01-29 23:31 被阅读0次

参考: golang操作mysql使用总结

建立测试数据表

CREATE TABLE `user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(25) NOT NULL DEFAULT '',
  `age` int(11) NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8

上代码

package main

import (
    // sql.DB 是接口协议,具体的DB操作是通过driver执行
    // 但是不能通过driver直接操作,需要通过接口操作,此处匿名引入,自动注册初始化到sql.DB中
    _ "github.com/go-sql-driver/mysql"
    "database/sql"
    "fmt"
)

/**
 * DB 连接池
 */
type DBWorker struct {
    Dsn string
    Db *sql.DB
}

// 对应数据表字段
type userTB struct {
    Id int
    Name sql.NullString   // 数据类型设置为 NullXXX,以便读取时判断是否赋值
    Age sql.NullInt64
}

func main()  {
    var err error
    dbw := DBWorker{
        // 格式大概为:user:password@protocol(ip:port)/database?charset=utf8
        Dsn: "root:XXXXXX(@tcp(localhost:3307)/test?charset=utf8",
    }
    dbw.Db, err = sql.Open("mysql", dbw.Dsn)
    if err != nil {
        panic(err)
        return
    }

    defer dbw.Db.Close()

    dbw.insertData()

    dbw.queryData()
}

// 插入数据测试
func (dbw* DBWorker) insertData()  {
    stmt, _ := dbw.Db.Prepare(`INSERT INTO user (name, age) VALUES (?, ?)`)

    defer stmt.Close()

    ret, err := stmt.Exec("虚无缥缈", 23)

    if err != nil {
        fmt.Printf("insert data error:%v\n", err)
        return
    }

    if LastInsertId, err := ret.LastInsertId(); err == nil {
        fmt.Printf("LastInsertId %d\n", LastInsertId)
    }

    if RowsAffected, err := ret.RowsAffected(); err == nil {
        fmt.Printf("RowsAffected %d\n", RowsAffected)
    }
}

// 查询数据测试
func (dbw *DBWorker) queryData()  {
    stmt, _ := dbw.Db.Prepare("SELECT * FROM user WHERE age >= ? and age < ?")

    defer stmt.Close()

    user := userTB{}

    rows, err := stmt.Query(20, 30)

    defer rows.Close()

    if err != nil {
        fmt.Printf("query data error : %v\n", err)
        return;
    }

    for rows.Next()  {
        // SCAN赋值的顺序需要与拉取出来的数据一一对应
        // 建表时是 id,name,age,此处赋值相对应的为Id, Name, Age
        err = rows.Scan(&user.Id, &user.Name, &user.Age)

        if err != nil {
            fmt.Printf("scan error : %v\n", err)
            continue
        }

        // 运行为空的情形下,给赋值默认值
        if !user.Name.Valid {
            user.Name.String = ""
        }

        // 运行为空的情形下,给赋值默认值
        if !user.Age.Valid {
            user.Age.Int64 = 0
        }

        fmt.Println("id: ", user.Id, " name: ", user.Name.String, " age: ", int(user.Age.Int64))
    }

    err = rows.Err()
    if err != nil {
        fmt.Printf("rows.Err: %v", err)
    }
}

运行结果

LastInsertId 7
RowsAffected 1
id:  1  name:  a  age:  25
id:  5  name:  石义波  age:  23
id:  6  name:  石义波  age:  23
id:  7  name:  虚无缥缈  age:  23

Process finished with exit code 0
image.png

结束语

相关文章

  • 3 MySQL数据库操作

    2 MySQL数据库操作 3.1 MySQL操作数据库 3.2 MySQL操作数据表 3.2.1 MySQL创建数...

  • 基于Linux的MySQL操作实例(软件安装,mysql基本操作

    基于Linux的MySQL操作实例(软件安装,mysql基本操作,mysql数据类型,建表、插入数据操作) 前言 ...

  • Mysql大全

    1.Mac下Homebrew 安装mysql 2.mysql管理 3.mysql数据库操作 4.mysql表操作 ...

  • php操作mysql语句

    mysql语句 php操作mysql语句

  • 搜企网爬虫作业

    作业要求 (1)csv文件数据写入(2)mysql 操作,python mysql操作 这个需要安装mysql以及...

  • python对mysql的操作

    python对mysql的操作 Mysql 常见操作 数据库操作 PS:用户权限相关数据保存在mysql数据库的u...

  • PHP操作mysql

    准备 事实上:PHP本身不能操作数据库(mysql);但是PHP有扩展可以实现操作mysql PHP操作mysql...

  • python作业-20170601

    作业:(1)csv文件数据写入(2)mysql 操作,python mysql操作 这个需要安装mysql以及p...

  • Go操作MySQL

    Go语言操作MySQL MySQL是业界常用的关系型数据库,本文介绍了Go语言如何操作MySQL数据库。 Go操作...

  • MySql笔记

    Mac安装并运行MySql MySql数据库、数据表的操作 MySql数据类型及常见约束 MySql表操作 MyS...

网友评论

      本文标题:Mysql操作

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