Logger

Logger

Gorm 有個 預設的記錄器實作,它會預設印出慢速 SQL 和發生的錯誤

記錄器接受一些選項,您可以在初始化期間自訂它,例如

newLogger := logger.New(
log.New(os.Stdout, "\r\n", log.LstdFlags), // io writer
logger.Config{
SlowThreshold: time.Second, // Slow SQL threshold
LogLevel: logger.Silent, // Log level
IgnoreRecordNotFoundError: true, // Ignore ErrRecordNotFound error for logger
ParameterizedQueries: true, // Don't include params in the SQL log
Colorful: false, // Disable color
},
)

// Globally mode
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
Logger: newLogger,
})

// Continuous session mode
tx := db.Session(&Session{Logger: newLogger})
tx.First(&user)
tx.Model(&user).Update("Age", 18)

記錄等級

GORM 定義的記錄等級:SilentErrorWarnInfo

db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
Logger: logger.Default.LogMode(logger.Silent),
})

偵錯

偵錯單一操作,將目前操作的記錄等級變更為 logger.Info

db.Debug().Where("name = ?", "jinzhu").First(&User{})

自訂記錄器

請參閱 GORM 的 預設記錄器,了解如何定義您自己的記錄器

記錄器需要實作以下介面,它接受 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)
}

白金贊助商

金牌贊助商

白金贊助商

金牌贊助商