搜索
首页后端开发Golang对于没有结果行的查询,我应该使用'DB.exec()”还是 Go 中的准备语句?

Should I Use `DB.exec()` or Prepared Statements in Go for Queries Without Result Rows?

破译在 Golang 中使用 *DB.exec() 和准备语句的难题

简介

领域中当使用 Go 和 Postgresql 进行数据库操作时,一个挥之不去的问题出现了:为什么要费心DB.exec() 或者当 Go 看起来自动创建它们时准备好的语句?本文深入研究了执行不返回行的操作的复杂性,并阐明了使用准备好的语句背后的基本原理。

为什么使用 DB.exec()

虽然 DB.Query() 确实如此,并且DB.exec() 可以互换使用来执行 SQL 语句,它们的不同之处在于返回的结果类型。 DB.exec() 提供有关受查询影响的行数的见解,而 DB.Query() 返回结果集。

例如,假设您希望执行 DELETE 语句并确定已删除的行数。使用 DB.exec() 是首选方法:

res, err := db.Exec(`DELETE FROM my_table WHERE expires_at = `, time.Now())
if err != nil {
    panic(err)
}

numDeleted, err := res.RowsAffected()
if err != nil {
    panic(err)
}
print(numDeleted)

或者,更麻烦的方法是使用 DB.Query() 并循环rows 来计算它们:

rows, err := db.Query(`DELETE FROM my_table WHERE expires_at =  RETURNING *`, time.Now())
if err != nil {
    panic(err)
}
defer rows.Close()

var numDeleted int
for rows.Next() {
    numDeleted += 1
}
if err := rows.Err(); err != nil {
    panic(err)
}
print(numDeleted)

此外,当查询结果不相关并且你只需要执行它,DB.exec()提供了一个简洁的解决方案:

if _, err := db.Exec(`<my_sql_query>`); err != nil {
    panic(err)
}</my_sql_query>

相反,在以下情况下省略返回的DB.Rows值的关闭调用:使用 DB.Query() 最终会因内存导致打开连接过载

深入研究准备好的语句

虽然有人建议 Go 自动创建准备好的语句,但现实似乎更加微妙。 DB.Query() 的行为似乎取决于所使用的底层驱动程序。

尽管如此,准备和重用 DB.Stmt 可以提高频繁执行的性能查询。浏览 Postgresql 官方文档,了解准备好的语句如何优化操作。

结论

理解 DB.exec() 和Golang 中的预准备语句可帮助开发人员高效执行不返回行的操作,并在寻求性能优化时利用预准备语句的优势。

以上是对于没有结果行的查询,我应该使用'DB.exec()”还是 Go 中的准备语句?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Golang在Debian上的安全设置Golang在Debian上的安全设置May 16, 2025 pm 01:15 PM

在Debian上设置Golang环境时,确保系统安全是至关重要的。以下是一些关键的安全设置步骤和建议,帮助您构建一个安全的Golang开发环境:安全设置步骤系统更新:在安装Golang之前,确保系统是最新的。使用以下命令更新系统软件包列表和已安装的软件包:sudoaptupdatesudoaptupgrade-y防火墙配置:安装并配置防火墙(如iptables)以限制对系统的访问。仅允许必要的端口(如HTTP、HTTPS和SSH)连接。sudoaptinstalliptablessud

Debian上Kubernetes部署的性能如何调优Debian上Kubernetes部署的性能如何调优May 16, 2025 pm 01:12 PM

在Debian上优化和部署Kubernetes集群的性能是一个涉及多个方面的复杂任务。以下是一些关键的优化策略和建议:硬件资源优化CPU:确保为Kubernetes节点和Pod分配足够的CPU资源。内存:增加节点的内存容量,特别是对于内存密集型应用。存储:使用高性能的SSD存储,避免使用网络文件系统(如NFS),因为它们可能会引入延迟。内核参数优化编辑/etc/sysctl.conf文件,添加或修改以下参数:net.core.somaxconn:65535net.ipv4.tcp_max_syn

Python脚本在Debian如何定时任务Python脚本在Debian如何定时任务May 16, 2025 pm 01:09 PM

在Debian系统中,你可以利用cron来安排定时任务,实现Python脚本的自动化执行。首先,启动终端。通过输入以下命令,编辑当前用户的crontab文件:crontab-e如果需要以root权限编辑其他用户的crontab文件,请使用:sudocrontab-uusername-e将username替换为你要编辑的用户名。在crontab文件中,你可以添加定时任务,格式如下:*****/path/to/your/python-script.py这五个星号分别代表分钟(0-59)、小

Debian如何配置Golang网络参数Debian如何配置Golang网络参数May 16, 2025 pm 01:06 PM

在Debian系统中调整Golang的网络参数可以通过多种方式实现,以下是几种可行的方法:方法一:通过设置环境变量临时设置环境变量:在终端中输入以下命令可以临时设置环境变量,此设置仅在当前会话有效。exportGODEBUG="gctrace=1netdns=go"其中,gctrace=1会激活垃圾回收跟踪,netdns=go则使Go使用其自身的DNS解析器而非系统默认的。永久设置环境变量:将上述命令添加到你的shell配置文件中,例如~/.bashrc或~/.profile

LibOffice在Debian上的快捷键有哪些LibOffice在Debian上的快捷键有哪些May 16, 2025 pm 01:03 PM

在Debian系统上自定义LibOffice的快捷键可以通过系统设置进行调整。以下是一些常用的步骤和方法来设置LibOffice的快捷键:设置LibOffice快捷键的基本步骤打开系统设置:在Debian系统中,点击左上角的菜单(通常是一个齿轮图标),然后选择“系统设置”。选择设备:在系统设置窗口中,选择“设备”。选择键盘:在设备设置页面中,选择“键盘”。找到对应工具的命令:在键盘设置页面中,向下滚动到最底部可以看到“快捷键”选项,点击它会弹出一个窗口。在弹出的窗口中找到对应LibOffice工

Debian部署Kubernetes有哪些注意事项Debian部署Kubernetes有哪些注意事项May 16, 2025 pm 01:00 PM

在Debian系统上部署Kubernetes(K8s)集群时,需要关注多个关键点,以确保集群的稳定性和安全性。以下是一些主要的注意事项:禁用Swap分区:从Kubernetes1.8版本开始,需要禁用Swap分区。可以使用以下命令临时禁用Swap:sudoswapoff-a若要永久禁用Swap,需编辑/etc/fstab文件,并注释掉包含“swap”的行。设置内核参数:启用IPv4转发:sudotee/etc/sysctl.d/k8s.conf设置网络参数,如net.bridge.brid

Kubernetes部署在Debian上有哪些优势Kubernetes部署在Debian上有哪些优势May 16, 2025 pm 12:57 PM

Kubernetes(简称K8s)在Debian上部署具有以下优势:稳定性:Debian是一个稳定且可靠的操作系统,适合作为Kubernetes的运行环境。许多教程推荐使用Debian12作为底层操作系统进行Kubernetes的部署,这表明Debian提供了可靠的运行环境,能够满足Kubernetes对操作系统的基本要求。安全性:Debian提供了强大的安全特性,如SELinux和AppArmor,可以进一步增强Kubernetes集群的安全性。通过合理的配置和优化措施,可以确保Kuberne

如何在Debian上部署Kubernetes集群如何在Debian上部署Kubernetes集群May 16, 2025 pm 12:54 PM

在Debian系统上部署Kubernetes集群可以通过多种方法实现,以下是利用kubeadm工具在Debian12上设置Kubernetes集群的详细步骤:预备工作确保你的Debian系统已经更新到最新版本。确保你拥有具有管理员权限的sudo用户。确保所有节点之间可以通过稳定网络互相连接。安装步骤设置主机名和更新hosts文件:在每个节点上,使用hostnamectl命令设置主机名,并在/etc/hosts文件中添加节点IP与主机名的对应关系。禁用所有节点的swap分区:为了让kubelet正

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具