获取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
相关推荐
XMYX-04 小时前
37 - Go env 环境变量:配置管理与运行时控制
开发语言·golang
姚不倒10 小时前
Go 进阶实战:实现泛型数据验证器
云原生·golang
XMYX-012 小时前
36 - Go exec 执行命令
开发语言·golang
lolo大魔王12 小时前
Go 语言 HTTP 协议与 RESTful API 实训全解(理论 + 实战 + 规范)
http·golang·restful
一只小逸白12 小时前
LeetCode Go 常用函数速查表
linux·leetcode·golang
LCG元13 小时前
【Go后端开发】从 0 到生产级:高性能分布式网关全实现 + 接口限流熔断降级实战
分布式·golang·wpf
姚不倒1 天前
Go语言进阶:接口、错误处理与并发编程(goroutine/channel/context)
云原生·golang
宇明一不急1 天前
go 链表 (标准库实现)
开发语言·链表·golang
~|Bernard|1 天前
GO语言中哪些类型是可比较类型的(==和!=)
开发语言·后端·golang
比特森林探险记1 天前
底层数据结构分析 go 语言中的 slice map channel interface
数据结构·golang·哈希算法