Logger
Gorm 有個 預設的記錄器實作,它會預設印出慢速 SQL 和發生的錯誤
記錄器接受一些選項,您可以在初始化期間自訂它,例如
newLogger := logger.New( log.New(os.Stdout, "\r\n", log.LstdFlags), logger.Config{ SlowThreshold: time.Second, LogLevel: logger.Silent, IgnoreRecordNotFoundError: true, ParameterizedQueries: true, Colorful: false, }, )
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{ Logger: newLogger, })
tx := db.Session(&Session{Logger: newLogger}) tx.First(&user) tx.Model(&user).Update("Age", 18)
|
記錄等級
GORM 定義的記錄等級:Silent
、Error
、Warn
、Info
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) }
|