登录
首页 >  Golang >  Go问答

gorm Raw原生查询 unsupported destination, should be slice or struct

来源:SegmentFault

时间:2023-02-24 09:59:14 405浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《gorm Raw原生查询 unsupported destination, should be slice or struct》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下gorm、SQL,希望所有认真读完的童鞋们,都有实质性的提高。

问题内容

使用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)

为何这里却不行了?

正确答案

不行的根源在于,你的

db
变量是
*gorm.DB
类型,它的
Raw
方法名不符实

gorm 所有基于

*gorm.DB
方法逻辑在于 表 --> 结构体 映射,获取结果集需要找到对应的表结构,也就是
destination
slice/struct
)。显而易见,
select database()
结果集与表结构无关,你用
gorm.DB
方法,是无解的。这点,你查阅
*gorm.DB.Scan
方法源码,会发现它会检测当前上下文对应表名(以确定列字段),找不到报上述错误很正常。

// *gorm.DB 的 Raw 方法与search 结构体相关,search 基于表查找
func (s *DB) Raw(sql string, values ...interface{}) *DB {
    return s.clone().search.Raw(true).Where(sql, values...).db
}

使用go原生的

*sql.DB
类型的
QueryRow
方法

正解如下,用

*gorm.DB
结构体的
DB()
方法获取
*sql.DB
类型

func showCurrentDb() {
    var database string
    persistence.GetDB().DB().QueryRow("select database()").Scan(&database)
    fmt.Println("database ", database)
}

理论要掌握,实操不能落!以上关于《gorm Raw原生查询 unsupported destination, should be slice or struct》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表