grom設置全局日志實現執(zhí)行并打印sql語句
更新時間:2025年03月02日 11:35:56 作者:code--cat
本文主要介紹了grom設置全局日志實現執(zhí)行并打印sql語句,包括設置日志級別、實現自定義Logger接口以及如何使用GORM的默認logger,通過這些方法,可以更好地控制和記錄數據庫操作的日志信息
gorm中的自定義日志
Gorm 有一個 默認 logger 實現,默認情況下,它會打印慢 SQL 和錯誤
Logger 接受的選項不多,您可以在初始化時自定義它,例如:
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(日志級別)
IgnoreRecordNotFoundError: true, // Ignore ErrRecordNotFound error for logger
ParameterizedQueries: true, // Don't include params in the SQL log(忽略記錄器的ErrRecordNotFound錯誤)
Colorful: true, // Disable color(禁用顏色)設置彩色打印
},
)
// Globally mode
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
Logger: newLogger,
})
gorm中日志的其他操作
日志級別
GORM 定義了這些日志級別:Silent、Error、Warn、Info
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
Logger: logger.Default.LogMode(logger.Silent),
})
Debug
Debug 單個操作,將當前操作的 log 級別調整為 logger.Info
db.Debug().Where("name = ?", "jinzhu").First(&User{})
自定義 Logger
參考 GORM 的 默認 logger 來定義您自己的 logger
Logger 需要實現以下接口,它接受 context,所以你可以用它來追蹤日志
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)
}
詳細內容可參考gorm官方文檔:https://gorm.io/zh_CN/docs/logger.html
到此這篇關于grom設置全局日志實現執(zhí)行并打印sql語句的文章就介紹到這了,更多相關grom設置全局日志 內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

