温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

golang使用sqlx捕捉错误的方法

发布时间:2020-06-17 11:25:02 来源:亿速云 阅读:363 作者:Leah 栏目:编程语言

这期内容当中小编将会给大家带来有关golang使用sqlx捕捉错误的方法,以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

使用命令即可

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捕捉错误的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI