获取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
相关推荐
(づど)10 小时前
解决VSCode中安装Go环境Gopls失败的问题
vscode·golang
wavemap1 天前
先到先得:免费订阅一年ChatGPT Go会员
开发语言·chatgpt·golang
浮尘笔记1 天前
Go并发编程核心:Mutex和RWMutex的用法
开发语言·后端·golang
百***06011 天前
【Golang】——Gin 框架中的表单处理与数据绑定
microsoft·golang·gin
百***93501 天前
【Golang】——Gin 框架中间件详解:从基础到实战
中间件·golang·gin
Tony Bai1 天前
Go 2025 密码学年度报告:后量子时代的防御与 FIPS 的“纯 Go”革命
开发语言·后端·golang·密码学
Like_wen1 天前
idea/goland 无法创建目标目录
java·golang
资深web全栈开发2 天前
Golang Cobra 教程:构建强大的CLI应用
开发语言·后端·golang
JCGKS2 天前
Go| excelize的流式迭代器
后端·golang·excel·excelize·流式读取·文件解析
自学AI的鲨鱼儿2 天前
cursor 使用 gvm管理的go的环境出现 Failed to find the “go“ binary in either GOROOT() 错误
golang·cursor·gvm