获取GORM执行时的sql字符串

示例:

go 复制代码
import "log"
func GetDetail(tx *gorm.DB,id int)(data any,err error){
	var query = tx.Session(&gorm.Session{DryRun: true})
	err = query.Where("id = ?", id).First(&res).Error
	if err!=nil{
		zap.L().Error("get detail error",zap.Error(err),zap.String("sql",query.Statement.SQL.String()))
	}
}

注意事项:

  1. 执行前需要事先声明Session,将DryRun设置为true
  2. 执行完First、Find、Delete 等方法后才能拿到SQL
相关推荐
OxyTheCrack11 小时前
【Golang】简述make与new内置函数以及两者的区别
开发语言·golang
会编程的土豆14 小时前
Go 方法接收者超清晰笔记(类型名 vs 变量名)
开发语言·笔记·golang
程序员卷卷狗15 小时前
Java转Go面试速记:Go基础22问,一篇理清高频易错点一篇理清高频易错点
java·面试·golang
会编程的土豆17 小时前
Go interface 底层的 itab 到底是什么
开发语言·后端·golang
non-action_pilgrim21 小时前
Go 高并发踩坑:关于在 for 循环里使用 time.After 后所进行的问题分析
golang
Yang961121 小时前
0.5 米超短盲区!鼎讯信通 GO-50PRO 光时域反射仪科普
开发语言·后端·golang
Reisentyan1 天前
[Pro]GoLang Learn Data Day 5
开发语言·后端·golang
geovindu1 天前
go: Bounded Parallelism Pattern
开发语言·后端·设计模式·golang·有界并行模式
小羊在睡觉1 天前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
ruxingli2 天前
Golang iota详解
开发语言·后端·golang