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

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

如何創建一個空的sql.Rows實例?

如何創建一個空的sql.Rows實例?

Go
MMMHUHU 2021-04-02 14:11:40
我有一個(*sql.Rows, error)在Go中返回的函數。在某些情況下,沒有任何返回值,但是也沒有錯誤。選擇似乎是:if (...) {    return nil, nil}然后,在調用方中:rows, err := fn()if err != nil {    return nil, err}if rows == nil {   ...} else {    for rows.Next() {    ...    }}否則返回一個特殊的錯誤,然后我檢查。我認為如果可以返回一個有效的Rows實例,將會更加優雅,但是除了Next()調用它的方法時返回false之外,它什么也沒有做,就像這樣:if (...) {    return EmptyRows(), nil}并且,在呼叫者中:rows, err := fn()if err != nil {    return nil, err}for rows.Next() {    ...}我可以做類似的事情:if (...) {    return db.QueryRows("select * from something where true=false"), nil}但這似乎很愚蠢。有什么建議嗎?
查看完整描述

1 回答

?
白衣染霜花

TA貢獻1796條經驗 獲得超10個贊

我將對此進行一些不同的處理,然后將處理程序傳遞給您的函數。因此,如果您的函數當前為:


func YourFunc() (*sql.Rows, error) {

    // ...

    if (...) {

        return nil, nil

    }

    return rows, nil

}

它將是:


func yourFunc() (*sql.Rows, error) {

    // ...

    if (...) {

        return nil, sql.ErrNoRows

    }

    return rows, nil

}


func YourFunc(cb func(*sql.Rows)) error {

    rows, err := yourFunc()

    if err == sql.ErrNoRows {

        return nil

    }

    if err != nil {

        return err

    }

    cb(rows)

    return nil

}

然后在您的呼叫者中:


err := YourFunc(func(row *sql.Rows) {

    for rows.Next() {

        // ...

    }

})

這將具有傳遞給您的函數,僅當存在行時才調用該函數,如果您關心的是行,則您將得到錯誤,并且調用方的語法很干凈。


查看完整回答
反對 回復 2021-04-19
  • 1 回答
  • 0 關注
  • 277 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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