获取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
相关推荐
稚辉君.MCA_P8_Java9 小时前
通义 Go 语言实现的插入排序(Insertion Sort)
数据结构·后端·算法·架构·golang
源代码•宸10 小时前
GoLang写一个简单版生命游戏模拟器
经验分享·笔记·学习·游戏·golang
q***017710 小时前
Linux 下安装 Golang环境
linux·运维·golang
稚辉君.MCA_P8_Java10 小时前
Gemini永久会员 Go 实现动态规划
数据结构·后端·算法·golang·动态规划
柠石榴12 小时前
go-1 模型
开发语言·后端·golang
想搞艺术的程序员1 天前
深入 NSQ 延迟消息实现原理:设计巧思与性能优化
性能优化·golang·nsq
(づど)1 天前
解决VSCode中安装Go环境Gopls失败的问题
vscode·golang
wavemap2 天前
先到先得:免费订阅一年ChatGPT Go会员
开发语言·chatgpt·golang
浮尘笔记2 天前
Go并发编程核心:Mutex和RWMutex的用法
开发语言·后端·golang
百***06012 天前
【Golang】——Gin 框架中的表单处理与数据绑定
microsoft·golang·gin