我試圖將 Go 中的錯(cuò)誤轉(zhuǎn)換為 go-sqlite3.Error,但它總是失敗。上圖代表我的調(diào)試窗口的快照,其中顯示錯(cuò)誤的類型為 go-sqlite3.Error我正在使用下面的代碼來(lái)類型轉(zhuǎn)換。import ( "github.com/mattn/go-sqlite3")if err != nil { if sqlite3Err, ok := err.(*sqlite3.Error); ok { if sqlite3Err.Code == sqlite3.ErrConstraint && sqlite3Err.ExtendedCode == 1555 { // SQLITE3 ERROR 1555 : PRIMARY KEY CONSTRAINT ERROR return errors.New("Log Error") } }
1 回答

慕森卡
TA貢獻(xiàn)1806條經(jīng)驗(yàn) 獲得超8個(gè)贊
嘗試以下示例。err.(*sqlite3.Error)更改為err.(sqlite3.Error)
if sqlite3Err, ok := err.(sqlite3.Error); ok {
if sqlite3Err.Code == sqlite3.ErrConstraint &&
sqlite3Err.ExtendedCode == 1555 {
// logic
}
}
- 1 回答
- 0 關(guān)注
- 198 瀏覽
添加回答
舉報(bào)
0/150
提交
取消