golang sqlx捕获毛病_后端开发

golang sqlx捕获毛病_后端开发

后端开发2019-12-15 2:49110ki4网

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捕获毛病的细致内容,更多请关注ki4网别的相干文章!

炫龙网络 Copyright ©  本站由阿里云强力驱动
golang sqlx捕获毛病_后端开发