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设置全局日志实现执行并打印sql语句的文章就介绍到这了,更多相关grom设置全局日志 内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |