问答

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

作者:admin 2021-05-07 我要评论

使用gorm查询 select database() ,结果报错,提示 unsupported destination, should be slice or struct 代码如下: func showCurrentDb() { var database stri...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

使用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 方法逻辑在于 表 --> 结构体 映射,获取结果集需要找到对应的表结构,也就是destinationslice/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)
}
###

你仔细看你的报错:unsupported destination, should be slice or struct
你使用的方法Scan(&database),报错提示应该用slice/struct类型,而你的参数&database所指向的数据类型不是slice/struct触发了报错
至于官方的例子使用了一个age是int类型,也不是slice/struct,这个可能需要查看下源码,最好查看下scan方法的源码

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • gorm Raw原生查询 unsupported destina

    gorm Raw原生查询 unsupported destina

  • 请问js字符串数组对象怎么转对象?

    请问js字符串数组对象怎么转对象?

  • 请问如何将文本中的"\n" 变成视觉上

    请问如何将文本中的"\n" 变成视觉上

  • 下载图片如何更改图片格式

    下载图片如何更改图片格式

腾讯云代理商
海外云服务器