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

更多相关文章

  1. golang中什么是接口
  2. Go接口interface的用法介绍
  3. golang接口可以嵌套吗
  4. Golang接口哪里好
  5. 关于 golang 的接口介绍
  6. 不是Web开发者所关注的XML基础具体分析
  7. 从TypeScript的类中派生接口[每日前端夜话0xAE]
  8. Apollo 源码解析 —— Config Service 配置读取接口
  9. 芋道 Spring Boot API 接口文档 Swagger 入门

随机推荐

  1. android 关于读取SD卡或者U盘的一些方法
  2. 【Android笔记】Activity涉及界面全屏的
  3. Android显示GIF动画完整示例(二)
  4. 使用Android Dropbox API检查Dropbox上是
  5. 【边做项目边学Android】手机安全卫士04_
  6. android开发中如何从当前页面返回上一页
  7. net. unknownhostexception:无法解析主机
  8. 【Android 开发教程】通过编码实现发送短
  9. Android功能模块化之网络连接状态判断
  10. Android Studio在连接手机时候,出现"Inst