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) }
文档中关于 Go 总是在幕后使用预准备语句的说法可能不正确。驱动程序实现似乎确定是否为每个 db.Query 调用创建一个新的准备好的语句。
但是,手动调用 db.Prepare 并缓存生成的 db.Stmt 可以增强频繁执行的查询的性能。有关更多详细信息,请参阅 PostgreSQL 文档:https://www.postgresql.org/docs/current/static/sql-prepare.html
以上是我何时以及为什么应该在 Go 中使用 `db.Exec()` 和准备好的语句?的详细内容。更多信息请关注PHP中文网其他相关文章!