
sqlx这个第三方库,用起来确实爽多了,这里记录下学习和用法的心得
安装:
使用命令即可 (推荐学习:go)
go get github.com/jmoiron/sqlx
介绍:
立即学习“go语言免费学习笔记(深入)”;
大意就是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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号