Logger

Gorm 有一个 默认 logger 实现,默认情况下,它会打印慢 SQL 和错误

Logger 接受的选项不多,您可以在初始化时自定义它,例如:

  1. newLogger := logger.New(
  2. log.New(os.Stdout, "\r\n", log.LstdFlags), // io writer
  3. logger.Config{
  4. SlowThreshold: time.Second, // 慢 SQL 阈值
  5. LogLevel: logger.Silent, // Log level
  6. Colorful: false, // 禁用彩色打印
  7. },
  8. )
  9. // 全局模式
  10. db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{
  11. Logger: newLogger,
  12. })
  13. // 新建会话模式
  14. tx := db.Session(&Session{Logger: newLogger})
  15. tx.First(&user)
  16. tx.Model(&user).Update("Age", 18)
  17. // Debug 单个操作,会将该会话的日志级别调整为 logger.Info
  18. db.Debug().Where("name = ?", "jinzhu").First(&User{})

日志级别

GORM 定义了这些日志级别:SilentErrorWarnInfo

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

自定义 Logger

您可用参考 GORM 的 默认 logger 来定义您自己的 logger

Logger 需要实现以下接口,它接受 context,所以你可以用它来追踪日志

  1. type Interface interface {
  2. LogMode(LogLevel) Interface
  3. Info(context.Context, string, ...interface{})
  4. Warn(context.Context, string, ...interface{})
  5. Error(context.Context, string, ...interface{})
  6. Trace(ctx context.Context, begin time.Time, fc func() (string, int64), err error)
  7. }