本文摘自php中文网,作者藏色散人,侵删。
下面由golang教程栏目给大家介绍关于Go SQL中的Query、Exec和Prepare使用对比(附网络抓包) ,希望对需要的朋友有所帮助!Go 附带的 database/sql 库可以与任何关系数据库进行对话. 为了抽象链接到数据库以及管理连接池的一些底层复杂性, 暴露的 APIs 比实际预期要多一点. 最终导致了一些关于如何使用这些 APIs 的想象.
因此, 我将尝试分析一下使用之前已知的主要 API 的行为.
我在主机的一个虚拟机 (ubuntu) 和一个 mysql 服务器上运行的 Go 应用程序进行了实验.
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’)”)
查看 wireshark 捕获 (query)
执行 Query(queryTemplate, params) 将在幕后 使用准备好的语句
- 注意从客户端向服务器发送了 3 个 TCP 请求 (减去登录)
- 当迭代完返回的 rows 时, 链接将自动释放回到池中, 或者我们可以在完成之后显式调用 rows.Close().
- 用法 — db.Query(“insert into items (name, price, description) values(?,?,?)”, “brownie”, 240, “sizzling”)
相关阅读 >>
leetcode154 寻找旋转排序数组中的最小值 ii golang
更多相关阅读请进入《golang》频道 >>

Go语言101
一个与时俱进的Go编程知识库。