获取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
相关推荐
木雷坞39 分钟前
Go 项目实战:用 MLiev IAM 落地企业认证中心
后端·golang·认证
知彼解己12 小时前
LLM-based Planning:从后端视角理解 Agent 规划层
后端·golang·ai编程
basketball61615 小时前
Go语言从入门到进阶:8. 接口
开发语言·后端·golang
codeejun17 小时前
每日一Go-71、理论知识:CAP 、一致性原理 、Raft 机制(简化实现一个 Raft)
java·开发语言·golang
曾几何时`17 小时前
Go(一)Gin框架 和 GORM机制
开发语言·golang·gin
l齐天18 小时前
Ubuntu 22.04 环境下 PBC 与 Golang 的安装、配置与测试
linux·ubuntu·golang
codeejun18 小时前
每日一 Go-72、分布式事务 & 一致性:本地消息表、事务消息、SAGA、TCC怎么选?
开发语言·分布式·golang
喵了几个咪2 天前
AI重构软件开发范式:框架与脚手架为何仍是生产级开发的刚需?
vue.js·人工智能·react.js·重构·golang·ai编程
go不是csgo2 天前
Go-GMP-调度器深度解析(改进版本)
java·linux·golang
知彼解己2 天前
SQLite 核心实战:后端工程师视角
后端·golang·ai编程