• 技术文章 >后端开发 >Golang

    golang sqlx捕捉错误

    (*-*)浩(*-*)浩2019-12-14 11:57:19原创1696

    sqlx这个第三方库,用起来确实爽多了,这里记录下学习和用法的心得

    安装:

    使用命令即可 (推荐学习:go

    go get github.com/jmoiron/sqlx

    介绍:

    大意就是sqlx是golang 标准database/sql的扩展,使用sqlx的接口跟原先的接口方法没什么两样,但有如下扩展:

    1.可将行记录映射如struct(内嵌struct也支持),map与slices <--这正是我之前想要的效果

    2.支持在preprared statement 中使用命名参数,在内置database/sql包之上增加了很多扩展,简化数据库操作代码的书写。

    3.Get 和Select的查询结果到struct/slice更快速

    sqlx也增加了许多接口,方便开发者使用,后面会讲到。

    package main
     
    import (
    	"database/sql"
    	_"github.com/go-sql-driver/mysql"
    	"github.com/jmoiron/sqlx"
    	"log"
    	"fmt"
    )
     
    type Student struct {
    	Id         int    `db:"id"`
    	Name       string `db:"name"`
    	Nick       string `db:"nick"`
    	Country    string `db:"country"`
    	Province   string `db:"province"`
    	City       string `db:"city"`
    	ImgUrl     string `db:"img_url"`
    	Status     int    `db:"status"`
    	CreateTime string `db:"create_time"`
    }
     
    func main()  {
    	dns := fmt.Sprintf("%s:%s@tcp(%s)/%s?charset=utf8", dbuser, dbpwd, dbhost, dbname)
    	db, err := sqlx.Connect("mysql", dns)
    	if err != nil {
            log.Fatalln(err)
    	}
    	defer db.Close()
     
    	tx := db.MustBegin()
    	tx.MustExec(`INSERT INTO student VALUES ('1', 'Jack', 'Jack', 'England', '', '', 'http://img2.imgtn.bdimg.com/it/u=3588772980,2454248748&fm=27&gp=0.jpg', '1', '2018-06-26 17:08:35');`)
    	tx.MustExec(`INSERT INTO student VALUES ('2', 'Emily', 'Emily', 'England', '', '', 'http://img2.imgtn.bdimg.com/it/u=3588772980,2454248748&fm=27&gp=0.jpg', '2', null);`)
    	err = tx.Commit()
    	if err != nil {
    		log.Fatalln(err)
    	}
     
    }

    以上就是golang sqlx捕捉错误的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:golang
    上一篇:golang map为啥不并发 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • golang读取文本乱码解决方法• cmd执行golang乱码解决方法• golang io读取文件与判断文件是否存在的方法• golang中“=”与“:=”的区别
    1/1

    PHP中文网