亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Golang 記錄 ID 為 0

Golang 記錄 ID 為 0

Go
拉風的咖菲貓 2023-03-29 15:39:48
我有以下汽車模型和汽車切片: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")


查看完整回答
反對 回復 2023-03-29
  • 1 回答
  • 0 關注
  • 149 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號