我试图在没有 where 条件的情况下查询 postgres 表中的所有结果,并通过传递 args ...interface {} 借助 sqlx db 查询将其映射到结构数组。但是下面粘贴的代码永远不会工作,而不是一一迭代和扫描结果,是否可以让以下代码工作?非常感谢您的投入。谢谢type CustomData struct { ID string `db:"id" json:",omitempty"` Name string `db:"name" json:",omitempty"` Description string `db:"description" json:",omitempty"` SourceID string `db:"sourceid" json:",omitempty"` StatusID string `db:"statusid" json:",omitempty"` StatusReason string `db:"statusreason" json:",omitempty"` CreateTime string `db:"createtime" json:",omitempty"` UpdateTime string `db:"updatetime" json:",omitempty"`}var myData []CustomData*sqlx.DB.Query("SELECT id as ID, name as Name, description as Description, sourceid as SourceID, statusid as StatusID, statusreason as StatusReason, createtime as CreateTime, updatetime as UpdateTime FROM myschema.my_table", &myData)// tried with following statement but din't work either// *sqlx.DB.Query("SELECT * FROM myschema.my_table", &myData) for _, data := range myData { fmt.Println("--", data) }预期成绩:--- 自定义数据{1,x,x,x,x} --- 自定义数据{2,x,x,x,x}实际情况:没什么..
2 回答
一只名叫tom的猫
TA贡献1906条经验 获得超3个赞
您不需要重命名查询中的字段,因为您正在结构标记中定义实际的数据库字段。
如果要直接扫描到 CustomData 切片并且使用 SQLX,则应使用 SQLX 特定的 Select 方法,而不是通用 SQL 查询。
pp := []Place{} err = db.Select(&pp, "SELECT * FROM place")
所以在你的情况下:
myData := []CustomData err = db.Select(&myData, "SELECT * FROM myschema.my_table")
喵喔喔
TA贡献1735条经验 获得超5个赞
您可以使用以下内容:
for rows.Next() {
s := CustomData{}
if err := rows.Scan(&s); err != nil {
return err
}
fmt.Println(s)
}
如果你喜欢代码优先方法,你总是可以使用 ORM 库作为gorm ;如果你喜欢数据库优先方法,你可以使用sqlboiler
- 2 回答
- 0 关注
- 179 浏览
添加回答
举报
0/150
提交
取消