第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

我可以在不先在Golang func中掃描的情況下從數(shù)據(jù)庫(kù)返回行結(jié)果嗎?

我可以在不先在Golang func中掃描的情況下從數(shù)據(jù)庫(kù)返回行結(jié)果嗎?

Go
拉丁的傳說(shuō) 2022-09-26 19:33:28
我有使用Golang的迷你項(xiàng)目,我的計(jì)劃是制作一個(gè)基本函數(shù),它將從模型中調(diào)用以執(zhí)行sql查詢,然后返回行結(jié)果而無(wú)需先掃描它。我正在使用這種方式來(lái)防止忘記編寫和代碼,以便在模型中執(zhí)行查詢更簡(jiǎn)單。我嘗試過這種方式,但是當(dāng)嘗試打印結(jié)果時(shí),我得到了零,沒有任何錯(cuò)誤。這是我的屏幕拍攝。當(dāng)執(zhí)行查詢和掃描的行結(jié)果在同一函數(shù)中時(shí),結(jié)果就存在。也許我錯(cuò)過了什么?這是我的第一個(gè)問題,抱歉它太長(zhǎng)了。謝謝defer rows.Close()將在其中執(zhí)行 SQL 查詢并返回結(jié)果的基本模型package modelimport "database/sql"import "hb-backend-v1/config/database"import "fmt"func Query(query string) (*sql.Rows, error){    connect, err := database.Connect()    if err != nil{        fmt.Println("Connection Failed")        return nil, err    }    fmt.Println("Connection Success")    defer connect.Close()    rows, err := connect.Query(query)    defer rows.Close()    if err != nil{        return nil, err    }    return rows, nil}
查看完整描述

1 回答

?
眼眸繁星

TA貢獻(xiàn)1873條經(jīng)驗(yàn) 獲得超9個(gè)贊

兩者一旦退出就會(huì)被關(guān)閉,在這兩個(gè)關(guān)閉后,您將無(wú)法再使用。connectionrowsQueryrows


解決這個(gè)問題的一種方法是傳遞一個(gè)閉包,并在關(guān)閉兩個(gè)資源之前執(zhí)行它:QueryQuery


func Query(query string, scan func(*sql.Rows) error) error {

    connect, err := database.Connect()

    if err != nil{

        return err

    }

    defer connect.Close()


    rows, err := connect.Query(query)

    if err != nil{

        return err

    }

    defer rows.Close()


    return scan(rows)

}

func ProductList() ([]Hasil, error) {

    var result []Hasil

    err := model.Query("SELECT * FROM alamat_store", func(rows *sql.Rows) error {

        for rows.Next() {

            var each = Hasil{}

            var err = rows.Scan(&each.Id_alamat_store, &each.Id_tk, &each.Alamat, &each.Id_wil, &each.Latitude, &each.Longitude)

            if err != nil {

                return err

            }

            result = append(result, each)

        }

        return nil

    })

    if err != nil {

        return nil, err

    }

    return result, nil

}


查看完整回答
反對(duì) 回復(fù) 2022-09-26
  • 1 回答
  • 0 關(guān)注
  • 96 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)