sqlx這個第三方函式庫,用起來確實爽多了,這裡記錄下學習和用法的心得
安裝:
使用指令即可 (建議學習:go)
go get github.com/jmoiron/sqlx
# 介紹:簡介時:#d ##大意就是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中文網其他相關文章!