获取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
相关推荐
卜锦元11 分钟前
Golang项目开发过程中好用的包整理归纳(附带不同包仓库地址)
开发语言·后端·golang
Tony Bai4 小时前
“我曾想付钱给 Google 去工作”—— Russ Cox 深度访谈:Go 的诞生、演进与未来
开发语言·后端·golang
海上彼尚7 小时前
Go之路 - 6.go的指针
开发语言·后端·golang
卜锦元13 小时前
Golang中make()和new()的区别与作用?
开发语言·后端·golang
海上彼尚13 小时前
Go之路 - 3.go的数据类型与转换
开发语言·后端·golang
龙门吹雪13 小时前
Go 语言包初始化顺序详解
golang·init·初始化顺序·依赖包·导入包
海上彼尚14 小时前
Go之路 - 4.go的集合[完整版]
开发语言·后端·golang
阿里巴啦15 小时前
从零搭建移动端数字人生成应用:React + Go + D‑ID 实战
react.js·golang·状态模式·数字人·did·ai移动端数字人
资深web全栈开发16 小时前
Go语言从1.18到1.25版本功能更新详解
开发语言·后端·golang
周杰伦_Jay17 小时前
【字节开源Golang框架Eino】技术详解:架构原理+实战落地+避坑指南(附代码)
架构·golang·开源