获取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
相关推荐
小羊在睡觉6 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
ruxingli15 小时前
Golang iota详解
开发语言·后端·golang
暗冰ཏོ17 小时前
Go 语言从入门到后端项目实战完整指南
开发语言·后端·golang·go·go语言
Reisentyan18 小时前
[Advance]GoLang Learn Data Day 4
java·数据库·golang
brycegao32118 小时前
Vue3+Go 全栈项目上线阿里云|从 0 到 1 踩坑全纪录
开发语言·阿里云·golang
会编程的土豆19 小时前
Go 里的 error 接口 + 假 nil(超级重点)
开发语言·后端·golang
basketball61620 小时前
Golang:基本输入输出使用方法总结
开发语言·golang·xcode
codeejun20 小时前
每日一Go-70、Prometheus + Grafana 从采集到告警的完整实战(Go + Kind)
golang·grafana·prometheus
会编程的土豆20 小时前
Go 里 interface 为什么能比较?到底在比什么?
开发语言·后端·golang
GDAL21 小时前
在 Windows 上做 Go 跨平台编
windows·golang