我有以下汽車模型和汽車切片:type Car struct { ID int `json:"id"` Name string `json:"title"`}var cars []Car在 Postgres 數據庫上,我創建了一個cars表來保存汽車記錄。create table cars (id serial, name varchar);并保存了一些汽車記錄:insert into cars (name) values ('Toyota');insert into cars (name) values ('Lexus');使用增量整數 ID 1 和 2 成功創建記錄。在我的 Go 服務器中,我進行以下查詢以獲取汽車記錄:db.Query("SELECT * from cars").Rows(&cars)for _, car := range cars { fmt.Println(car)}雖然有響應,但每條記錄的 id 都為 0。我試圖找出原因,但無法找到。有人知道嗎?
1 回答

哆啦的時光機
TA貢獻1779條經驗 獲得超6個贊
database/sql包不提供直接將數據掃描到結構中,您應該遍歷從數據庫查詢返回的行,然后將數據掃描到結構中,如下所示:
var cars []cars
for rows.Next() {
var car cars
err = rows.Scan(&c.ID, &c.Name)
if err != nil {
log.Fatalf("Scan: %v", err)
}
cars = append(cars, car)
}
fmt.Println(cars)
或者您可以使用 sql 包名稱sqlx的擴展名,這將使您可以直接將結果掃描到結構的切片中,如下所示:
cars := []cars{}
db.Select(&cars, "SELECT * from cars")
- 1 回答
- 0 關注
- 149 瀏覽
添加回答
舉報
0/150
提交
取消