我想编写一个处理 SQL 查询的通用函数。
Sqlx模块提供函数StructScan()
,它自动将结果扫描到结构字段中。
type Place struct {
Country string
City sql.NullString
TelephoneCode int `db:"telcode"`
}
rows, err := db.Queryx("SELECT * FROM place")
for rows.Next() {
var p Place
err = rows.StructScan(&p)
}
因此,建议的函数签名如下所示:
func Query(db *sql.DB, query) {
rows, err := db.Queryx("SELECT * FROM place")
for rows.Next() {
var p CustomType
err = rows.StructScan(&p)
}
}
问题是我事先不知道表示为自定义类型的变量的确切类型,因为它因特定查询而异(某些查询返回string,另一个int等)。
一种选择是将类型 CustomType
作为参数传递给Query
. 但是,我不知道如何p
使用所需类型初始化局部变量。
有没有办法做到这一点?