首页 > 后端开发 > Golang > 正文

Go SQLCMD 比 Windows 原生版本慢吗?

PHPz
发布: 2024-02-08 23:57:09
转载
498人浏览过

go sqlcmd 比 windows 原生版本慢吗?

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

问题内容

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

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

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

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

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

标书对比王
标书对比王

标书对比王是一款标书查重工具,支持多份投标文件两两相互比对,重复内容高亮标记,可快速定位重复内容原文所在位置,并可导出比对报告。

标书对比王 58
查看详情 标书对比王

解决方法

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

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

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

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:stackoverflow网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号