我想编写一个处理SQL查询的泛型函数。
Sqlx模块提供函数StructScan()
,它会自动将结果扫描到struct字段中。
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)
}
}
问题在于我事先并不知道变量的确切类型表示为自定义类型,因为它根据特定查询而有所不同(某些查询返回字符串,另一个 int < / strong>等)。
其中一个选项是将类型 CustomType
作为参数传递给Query
。但是,我不知道如何使用所需类型初始化局部变量p
。
有办法吗?