不行的根源在于,你的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)
}
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…