首页 >后端开发 >Golang >我何时以及为什么应该在 Go 中使用 `db.Exec()` 和准备好的语句?

我何时以及为什么应该在 Go 中使用 `db.Exec()` 和准备好的语句?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-07 22:37:151001浏览

When and Why Should I Use `db.Exec()` and Prepared Statements in Go?

为什么要在 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