我何时以及为什么应该在 Go 中使用 `db.Exec()` 和准备好的语句?
为什么要在 Golang 中使用 *DB.exec() 或准备好的语句?
“为什么要使用 db.Exec()”
While对于相同的 SQL 语句,您可以互换使用 db.Exec 和 db.Query,它们会产生不同的结果。 db.Exec 返回受影响的行数(如果驱动程序支持),而 db.Query 返回 rows 对象。
例如,要计算 DELETE 语句中删除的行数:
res, err := db.Exec(`DELETE FROM my_table WHERE expires_at = `, time.Now()) numDeleted, err := res.RowsAffected() // Returns the number of deleted rows
登录后复制
替代方案(但效率较低):
rows, err := db.Query(`DELETE FROM my_table WHERE expires_at = RETURNING *`, time.Now()) numDeleted := 0 for rows.Next() { numDeleted++ } // Iterate over deleted rows
登录后复制
当您不这样做时也应该使用 db.Exec需要查询结果,只需进行错误检查:
if _, err := db.Exec(`<my_sql_query>`); err != nil { panic(err) }
登录后复制
“或者 Golang 中的预准备语句?”
文档中关于 Go 总是在幕后使用预准备语句的说法可能不正确。驱动程序实现似乎确定是否为每个 db.Query 调用创建一个新的准备好的语句。
但是,手动调用 db.Prepare 并缓存生成的 db.Stmt 可以增强频繁执行的查询的性能。有关更多详细信息,请参阅 PostgreSQL 文档:https://www.postgresql.org/docs/current/static/sql-prepare.html
以上是我何时以及为什么应该在 Go 中使用 `db.Exec()` 和准备好的语句?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前
By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保护它?
3 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

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

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)