grom設(shè)置全局日志實(shí)現(xiàn)執(zhí)行并打印sql語(yǔ)句
gorm中的自定義日志
Gorm 有一個(gè) 默認(rèn) logger 實(shí)現(xiàn),默認(rèn)情況下,它會(huì)打印慢 SQL 和錯(cuò)誤
Logger 接受的選項(xiàng)不多,您可以在初始化時(shí)自定義它,例如:
newLogger := logger.New( log.New(os.Stdout, "\r\n", log.LstdFlags), // io writer logger.Config{ SlowThreshold: time.Second, // Slow SQL threshold(慢速SQL閾值) LogLevel: logger.info, // Log level(日志級(jí)別) IgnoreRecordNotFoundError: true, // Ignore ErrRecordNotFound error for logger ParameterizedQueries: true, // Don't include params in the SQL log(忽略記錄器的ErrRecordNotFound錯(cuò)誤) Colorful: true, // Disable color(禁用顏色)設(shè)置彩色打印 }, ) // Globally mode db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{ Logger: newLogger, })
gorm中日志的其他操作
日志級(jí)別
GORM 定義了這些日志級(jí)別:Silent、Error、Warn、Info
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{ Logger: logger.Default.LogMode(logger.Silent), })
Debug
Debug 單個(gè)操作,將當(dāng)前操作的 log 級(jí)別調(diào)整為 logger.Info
db.Debug().Where("name = ?", "jinzhu").First(&User{})
自定義 Logger
參考 GORM 的 默認(rèn) logger 來(lái)定義您自己的 logger
Logger 需要實(shí)現(xiàn)以下接口,它接受 context,所以你可以用它來(lái)追蹤日志
type Interface interface { LogMode(LogLevel) Interface Info(context.Context, string, ...interface{}) Warn(context.Context, string, ...interface{}) Error(context.Context, string, ...interface{}) Trace(ctx context.Context, begin time.Time, fc func() (sql string, rowsAffected int64), err error) }
詳細(xì)內(nèi)容可參考gorm官方文檔:https://gorm.io/zh_CN/docs/logger.html
到此這篇關(guān)于grom設(shè)置全局日志實(shí)現(xiàn)執(zhí)行并打印sql語(yǔ)句的文章就介紹到這了,更多相關(guān)grom設(shè)置全局日志 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
簡(jiǎn)介Go語(yǔ)言中的select語(yǔ)句的用法
這篇文章主要介紹了簡(jiǎn)介Go語(yǔ)言中的select語(yǔ)句的用法,是golang入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-10-10使用Go中的Web3庫(kù)進(jìn)行區(qū)塊鏈開(kāi)發(fā)的案例
區(qū)塊鏈作為一種分布式賬本技術(shù),在近年來(lái)取得了巨大的發(fā)展,而Golang作為一種高效、并發(fā)性強(qiáng)的編程語(yǔ)言,被廣泛用于區(qū)塊鏈開(kāi)發(fā)中,本文將介紹如何使用Golang中的Web3庫(kù)進(jìn)行區(qū)塊鏈開(kāi)發(fā),并提供一些實(shí)際案例,需要的朋友可以參考下2023-10-10golang 的string與[]byte轉(zhuǎn)換方式
這篇文章主要介紹了golang 的string與[]byte轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04Go語(yǔ)言基礎(chǔ)函數(shù)基本用法及示例詳解
這篇文章主要為大家介紹了Go語(yǔ)言基礎(chǔ)函數(shù)基本用法及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-11-11go build 通過(guò)文件名后綴實(shí)現(xiàn)不同平臺(tái)的條件編譯操作
這篇文章主要介紹了go build 通過(guò)文件名后綴實(shí)現(xiàn)不同平臺(tái)的條件編譯操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12