關於Go SQL中的Query、Exec和Prepare使用對比(附網路抓包)
下面由golang教學專欄跟大家介紹關於關於關於關於關於關於關於Go SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用比較(附網路抓包) ,希望對需要的朋友有幫助!
關於關於關於關於關於關於Go SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) 附帶的database/sql 庫可以與任何關係資料庫進行對話. 為了抽象連結到資料庫以及管理連接池的一些底層複雜性, 暴露的APIs 比實際預期要多一點. 最終導致了一些關於如何使用這些APIs 的想像.
因此, 我將嘗試分析一下使用之前已知的主要API 的行為.
我在主機的一個虛擬機器(ubuntu) 和一個mysql 伺服器上運行的關於關於關於關於關於關於Go SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) SQL中的Query、Exec和Prepare使用對比(附網路抓包) 應用程式進行了實驗.
## Query tried: insert into items (name, price, description) values ('brownie',240,'sizzling')
查詢
每當我們進行select 時都應該是始終使用db.Query, 並且我們絕不應該護理Query 返回的rows, 而應對其進行迭代(否則我們會洩露數據庫鏈接)
執行Query(query) 將不使用準備好的語句(可參閱下面的wireshark 擷取內容)
- 注意從客戶端到伺服器僅發送了1 個TCP 請求(減去登入)
- 當迭代返回的rows 時連結將自動釋放回池中, 或則我們可以在完成之後明確調用rows.Close()
- 用法—
- db.Query(“insert into items (name, price, description) values('brownie', 240, 'sizzling')”)
執行#Query(queryTemplate, params) 將在幕後使用準備好的語句
- 注意從客戶端向伺服器發送了3 個TCP 請求(減去登入)
- 當迭代完返回的rows 時, 連結將自動釋放回池中, 或者我們可以在完成之後明確地呼叫rows.Close().
- 用法— db.Query(“insert into items (name, price, description) values(?,?,?)”, “brownie”, 240, “sizzling”)
Exec
每當我們想要執行insert 或update 或delete 時都應該要永遠使用db.Exec
.執行Exec(query)
不會使用預備語句, 因此對SQL Server 的TCP 呼叫更少- 注意從客戶端到伺服器只發送了1 個TCP 請求(減去登入)
- 自動釋放連結回到池.
- #用法— db.Exec(“insert into items (name, price, description ) values('brownie', 240, 'sizzling')”)
#執行Exec(queryTemplate, params)
將在幕後使用預備語句, 因此對SQL Server 的TCP 呼叫會多一些.- 注意從客戶端向伺服器發送了3 個TCP請求(減去登入)
- 釋放連結自動回到池.
- 用法— #db.Exec(“insert into items (name, price, description) values(?,? ,?)”, “brownie”, 240, “sizzling”)
#Prepare
僅當我們的程式要在開始時準備一次並在程式執行期間執行N 次時, 才應使用此方法.- 注意有從客戶端到服務端發送了2 個TCP 請求(不算登入)
- 當我們不需要預備語句時我們需要明確關閉語句. 否則, 我們將無法釋放客戶端和伺服器上分配的資源!
- 用法— stmt.Exec(“insert into items (name, price, description) values(?,?,?)”, “brownie”, 240, “sizzling”)
希望上述內容可以闡述清楚, 我們應該何時使用預備語句以及如何規避它們.
Hopefully the points above clarify, when are prepared statements invoked and how we can avoid them.
以上是關於Go SQL中的Query、Exec和Prepare使用對比(附網路抓包)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

在Go中安全地讀取和寫入檔案至關重要。指南包括:檢查檔案權限使用defer關閉檔案驗證檔案路徑使用上下文逾時遵循這些準則可確保資料的安全性和應用程式的健全性。

如何為Go資料庫連線配置連線池?使用database/sql包中的DB類型建立資料庫連線;設定MaxOpenConns以控制最大並發連線數;設定MaxIdleConns以設定最大空閒連線數;設定ConnMaxLifetime以控制連線的最大生命週期。

Go框架憑藉高效能和並發性優勢脫穎而出,但也存在一些缺點,例如相對較新、開發者生態系統較小、缺乏某些功能。此外,快速變化和學習曲線可能因框架而異。 Gin框架以其高效路由、內建JSON支援和強大的錯誤處理而成為建立RESTfulAPI的熱門選擇。

GoLang框架與Go框架的差異體現在內部架構與外部特性。 GoLang框架基於Go標準函式庫,擴充其功能,而Go框架由獨立函式庫組成,以實現特定目的。 GoLang框架更靈活,Go框架更容易上手。 GoLang框架在效能上稍有優勢,Go框架的可擴充性更高。案例:gin-gonic(Go框架)用於建立RESTAPI,而Echo(GoLang框架)用於建立Web應用程式。

可以透過使用gjson函式庫或json.Unmarshal函數將JSON資料儲存到MySQL資料庫中。 gjson函式庫提供了方便的方法來解析JSON字段,而json.Unmarshal函數需要一個目標類型指標來解組JSON資料。這兩種方法都需要準備SQL語句和執行插入操作來將資料持久化到資料庫中。

最佳實踐:使用明確定義的錯誤類型(errors套件)建立自訂錯誤提供更多詳細資訊適當記錄錯誤正確傳播錯誤,避免隱藏或抑制根據需要包裝錯誤以添加上下文

如何在Go框架中解決常見的安全問題隨著Go框架在Web開發中的廣泛採用,確保其安全至關重要。以下是解決常見安全問題的實用指南,附帶範例程式碼:1.SQL注入使用預編譯語句或參數化查詢來防止SQL注入攻擊。例如:constquery="SELECT*FROMusersWHEREusername=?"stmt,err:=db.Prepare(query)iferr!=nil{//Handleerror}err=stmt.QueryR

後端學習路徑:從前端轉型到後端的探索之旅作為一名從前端開發轉型的後端初學者,你已經有了nodejs的基礎,...
