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

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

如何從 golang MySQL 包中獲取精細的 LOAD DATA 結果?

如何從 golang MySQL 包中獲取精細的 LOAD DATA 結果?

Go
呼如林 2022-07-18 16:04:56
我正在編寫一個與 MySQL 數據庫交互的 Go 程序。在 MySQL 中,當您進行LOAD DATA查詢時,除了常規X rows affected行之外,您還會獲得包含更詳細信息的行:mysql> LOAD DATA LOCAL INFILE 'many-lines.tsv' REPLACE INTO TABLE test_table (id, timestamp);Query OK, 6 rows affected (0.01 sec)Records: 3  Deleted: 3  Skipped: 0  Warnings: 0如“聲明結果信息”部分所述。我希望能夠從我的 Go 程序中訪問它,但我不知道如何,甚至是否可能。sql.DB.Exec()返回一個Result,但它只有一個RowsAffected字段。這包含寫入的行 + 刪除的行的總和并忽略跳過的行,因此是不明確的(寫入 3、刪除 2 和跳過 2 與寫入 5、刪除 0 和跳過 0 相同)。我查看了 Go MySQL driver 的文檔,但找不到任何我想要的東西。有沒有辦法訪問這些信息?
查看完整描述

1 回答

?
幕布斯6054654

TA貢獻1876條經驗 獲得超7個贊

該信息實際上是服務器的ER_LOAD_INFO “錯誤”(名義上是信息)消息。

這在來自服務器的OK 響應中作為信息性消息進行通信。

查看go 中 OK 數據包的解碼,它沒有解析出info(人類可讀的狀態信息)。建立連接時,請確保clientSessionTrack是連接標志的一部分。

因此,對 Go MySQL 驅動程序進行了一些小的改進,您將能夠訪問它。


查看完整回答
反對 回復 2022-07-18
  • 1 回答
  • 0 關注
  • 130 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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