gorm Raw原生查询 unsupported destination, should be slice or struct
使用gorm查询select database()
,结果报错,提示 unsupported destination, should be slice or struct
代码如下:
func showCurrentDb() {
var database string
persistence.GetDB().Raw("select database()").Scan(&database)
fmt.Println("database ", database)
}
官方有一个例子
https://gorm.io/docs/sql_buil...
var age int
db.Raw("select sum(age) from users where role = ?", "admin").Scan(&age)
为何这里却不行了?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
不行的根源在于,你的
db
变量是*gorm.DB
类型,它的Raw
方法名不符实gorm 所有基于
*gorm.DB
方法逻辑在于 表 --> 结构体 映射,获取结果集需要找到对应的表结构,也就是destination
(slice/struct
)。显而易见,select database()
结果集与表结构无关,你用gorm.DB
方法,是无解的。这点,你查阅*gorm.DB.Scan
方法源码,会发现它会检测当前上下文对应表名(以确定列字段),找不到报上述错误很正常。使用go原生的
*sql.DB
类型的QueryRow
方法正解如下,用
*gorm.DB
结构体的DB()
方法获取*sql.DB
类型你仔细看你的报错:
unsupported destination, should be slice or struct
你使用的方法Scan(&database),报错提示应该用slice/struct类型,而你的参数&database所指向的数据类型不是slice/struct触发了报错
至于官方的例子使用了一个age是int类型,也不是slice/struct,这个可能需要查看下源码,最好查看下scan方法的源码