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

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

golang 數(shù)據(jù)庫事務(wù):如果單個 exec 語句失敗則繼續(xù)

golang 數(shù)據(jù)庫事務(wù):如果單個 exec 語句失敗則繼續(xù)

Go
暮色呼如 2023-04-04 15:34:36
我正在編寫一個 Go 應(yīng)用程序,它應(yīng)該將文件中的數(shù)千個值插入到數(shù)據(jù)庫中。這工作正常,只要所有值都可以插入到數(shù)據(jù)庫中。如果其中一個查詢失敗,則之后的所有查詢都會失敗,因為pq: : current transaction is aborted, commands ignored until end of transaction block我想插入所有元素,如果一個元素的插入失敗,應(yīng)該跳過它并插入其他元素。我的代碼:func (db *Database) Insert(values []Value) (transerr error) {    tx, err := db.Begin()    if transerr != nil {        return nil, err    }    defer func() {        if err != nil {            tx.Rollback()        } else {            tx.Commit()        }    }    stmt, err := tx.Prepare("INSERT INTO foo VALUES (?)")    if err != nil {        return err    }    defer stmt.Close()    for _, value : range values {        _, err = stmt.Exec(value)        if err != nil {            log.Error(err)        }    }    return nil}我試圖添加一個 tx.Rollback() 以防 stmt.Exec 失敗——但這會導(dǎo)致sql: statement is closed.
查看完整描述

2 回答

?
斯蒂芬大帝

TA貢獻1827條經(jīng)驗 獲得超8個贊

對于 Postgresql,您可以使用ON CONFLICT DO NOTHING


我已經(jīng)在我這邊用 postgresql db 嘗試了下面的代碼,它忽略了有錯誤的插入行。我做了一些其他的改變來嘗試在我這邊。您可以忽略我的其他更改。


func insert(db *sql.DB, values []string) error {

    tx, err := db.Begin()

    if err != nil {

        return err

    }

    defer tx.Commit()

    stmt, err := tx.Prepare("INSERT INTO foo (  foo_col) VALUES ($1) ON CONFLICT DO NOTHING")


    if err != nil {

        fmt.Println("errro at stmt", err)

        return err

    }


    defer stmt.Close()


    for _, value := range values {

        _, err = stmt.Exec(value)

        if err != nil {

            fmt.Println(value, err)

        }

    }

    return nil

}

對于 mysql,你可以使用INSERT IGNORE


stmt, err := tx.Prepare("INSERT IGNORE INTO foo (  foo_col) VALUES ($1) ")


查看完整回答
反對 回復(fù) 2023-04-04
?
翻過高山走不出你

TA貢獻1875條經(jīng)驗 獲得超3個贊

我對該問題的解決方案如下所示:

  • 不要創(chuàng)建單個事務(wù)并將所有語句添加到其中,而只是運行它而不創(chuàng)建事務(wù)。

  • 當(dāng)值被讀入時,生成新的 go 例程并讓事務(wù)并行運行(注意連接限制)。

  • 沒有并行化,性能下降了大約 30%(從 25k 值的 20s 到 30s——我們之前沒有使用并行化)。

  • 通過并行化,性能提高了大約 4 倍(達到 5 秒)——請注意保持在連接范圍內(nèi)


查看完整回答
反對 回復(fù) 2023-04-04
  • 2 回答
  • 0 關(guān)注
  • 246 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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