如何屏蔽GORM个别sql的日志

背景:

gorm开启了日志,有个表存储大的二进制数据,导致日志文件很大,而且二进制导致乱码。

需求:

屏蔽这个表的sql日志,不要影响其他表的sql日志。

实验:

gorm_log.go

Go 复制代码
package main

import (
	"context"
	"database/sql"
	"fmt"
	"log"
	"net/url"

	"gorm.io/gorm/logger"

	"time"

	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

type Params struct {
	Id    int64  `gorm:"id" json:"id"`
	Key   string `gorm:"key" json:"key"`
	Value string `gorm:"value" json:"value"`
}

func (Params) TableName() string {
	return "params"
}

func main() {
	encodedPassword := url.QueryEscape("mypassword")
	dsn := "root:" + encodedPassword + "@tcp(127.0.0.1:3306)/mydbname?charset=utf8mb4&parseTime=True&loc=Local"
	//fmt.Println(dsn)
	newLogger := logger.New(
		log.New(log.Writer(), "\r\n", log.LstdFlags), // io writer
		logger.Config{
			SlowThreshold:             time.Second, // 慢SQL阈值
			LogLevel:                  logger.Info, // 日志级别
			IgnoreRecordNotFoundError: true,        // 忽略ErrRecordNotFound(记录未找到)错误
			Colorful:                  true,        // 启用彩色打印
		},
	)
	gormDB, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
		Logger: newLogger,
	})
	if err != nil {
		log.Fatal(err)
	}
	sqlDB, err := gormDB.DB()
	if err != nil {
		log.Fatal(err)
	}

	// 常规的gorm用法
	fmt.Println("--- gorm start ---")
	var params Params
	sqlResult := gormDB.First(&params, 1)
	if sqlResult.Error != nil {
		log.Fatal(sqlResult.Error)
	}
	fmt.Println(params)
	fmt.Println("--- gorm end ---")

	// gorm.DB使用原生SQL查询
	fmt.Println("--- gorm.DB with raw sql start ---")
	var result struct {
		Count int
	}
	err = gormDB.Raw("SELECT COUNT(*) as count FROM params").Scan(&result.Count).Error
	if err != nil {
		log.Fatal(err)
	}
	fmt.Printf("count: %d\n", result.Count)
	fmt.Println("--- gorm.DB with raw sql end ---")

	// sql.DB使用原生SQL查询
	fmt.Println("--- sql.DB with raw sql start ---")
	err = sqlDB.QueryRow("SELECT COUNT(*) as count FROM params").Scan(&result.Count)
	if err != nil {
		log.Fatal(err)
	}
	fmt.Printf("count: %d\n", result.Count)
	fmt.Println("--- sql.DB with raw sql end ---")

	// 使用真正的原生SQL(不依赖GORM)
	fmt.Println("--- golang raw sql start ---")
	useNativeSQL(sqlDB)
	fmt.Println("--- golang raw sql end ---")

	// 直接使用日志方法自己打印日志
	fmt.Println("--- gorm log start ---")
	gormDB.Logger.Info(context.TODO(), "gorm log is here")
	fmt.Println("--- gorm log end ---")
}

func useNativeSQL(db *sql.DB) {
	rows, err := db.Query("SELECT `key`, value FROM params limit 3")
	if err != nil {
		log.Fatal(err)
	}
	defer rows.Close()
	for rows.Next() {
		var key, value string
		err = rows.Scan(&key, &value)
		if err != nil {
			log.Fatal(err)
		}
		fmt.Printf("key: %s, value: %s\n", key, value)
	}
	if err = rows.Err(); err != nil {
		log.Fatal(err)
	}
}

运行:

bash 复制代码
go mod init gormtest
go mod tidy
go run gorm_log.go

输出:

结论:

1、gorm常规用法和通过grom.DB的原生用法都会有日志。

2、通过gorm获取sql.DB然后执行原生sql不会有日志。

3、通过gorm获取sql.DB然后使用golang的原生sql写法不会有日志。

4、通过gormDB.Logger可以自己打印出类似形式的日志。

--end--

相关推荐
剩下了什么1 天前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥1 天前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉1 天前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变1 天前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
山岚的运维笔记1 天前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里1 天前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科1 天前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦1 天前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
WHD3061 天前
苏州数据库(SQL Oracle)文件损坏修复
hadoop·sql·sqlite·flume·memcached
晚霞的不甘1 天前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d