返回顶部
首页 > 资讯 > 精选 >Go SQLCMD 比 Windows 原生版本慢吗?
  • 414
分享到

Go SQLCMD 比 Windows 原生版本慢吗?

2024-02-09 05:02:20 414人浏览 安东尼
摘要

PHP小编小新,你是否经常使用sqlCMD工具来管理和操作数据库?你是否曾经对比过windows原生版本和Go SQLCMD的性能差异?如果你有这些疑问,那么今天我们就来探讨一下这个话

PHP小编小新,你是否经常使用sqlCMD工具来管理和操作数据库?你是否曾经对比过windows原生版本和Go SQLCMD的性能差异?如果你有这些疑问,那么今天我们就来探讨一下这个话题。在本文中,我们将对比这两个版本的性能,并给出答案,Go SQLCMD是否比Windows原生版本慢。让我们一起来看看吧!

问题内容

我一直在使用 Windows 本地 sqlcmd 在本地 SQL Server 数据库上运行脚本。我有一组脚本文件,用于创建数据库、添加表和索引、填充域数据、添加存储过程等。运行脚本是通过每个文件执行一个 sqlcmd -i .sql 来完成的。这运作良好并且足够快。 切换到 sqlcmd 的新 Go 实现后,数据库构建时间慢了几倍。

我一直无法找到任何方法从sqlcmd获取计时类型的统计信息来确定是否是连接问题、连接池或其他问题。如果我将多个文件作为附加的 -i 选项传递,我可以看到看起来有什么改进,这向我表明这是 Go 命令启动或初始数据库连接建立的问题。 p>

我做了一个测试,我拿了十个 SQL 文件,并将它们作为十个单独的 sqlcmd 执行来运行,也作为一个 sqlcmd 执行来运行,这十个文件作为单独的 -i 输入文件。单独的命令需要 20 秒,综合命令需要 4 秒。因此,这似乎是启动开销或连接开销的问题。

根据 @siggemannen 的建议,我使用 AD 凭据和直接数据库用户测试了连接。 AD 凭据比直接数据库连接慢得多,这意味着这是我在场景中看到的缓慢的根源。

我正在寻找任何建议或想法来解决问题或进一步排除故障。有什么办法可以加快 AD 身份验证的速度吗?

解决方法

Go sqlcmd 并不比原生版本慢。使用 Windows/AD 凭据建立连接会增加建立连接所需的启动时间,并且在用例中为每个 sqlcmd 实例运行一个 SQL 文件,这会增加额外的开销。

我们可以重新编写构建脚本,以便为每个单独的 sqlcmd 运行许多 SQL 文件,这将恢复我们所需的性能。但是,我们无需任何返工即可使用的替代方案是使用 SQL Server 级别主体 sa 在创建数据库时创建。这恢复了与使用 AD 登录的本机 sqlcmd 相当的性能。

以上就是Go SQLCMD 比 Windows 原生版本慢吗?的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: Go SQLCMD 比 Windows 原生版本慢吗?

本文链接: https://lsjlt.com/news/562237.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作