ロガー
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) }
|