搜尋
首頁後端開發GolangGo SQLCMD 比 Windows 原生版本慢嗎?

Go SQLCMD 比 Windows 原生版本慢吗?

php小編小新,你是否常用SQLCMD工具來管理和操作資料庫?你是否曾經比較過Windows原生版本和Go SQLCMD的效能差異?如果你有這些疑問,那麼今天我們就來探討這個主題。在本文中,我們將比較這兩個版本的效能,並給出答案,Go SQLCMD是否比Windows原生版本慢。讓我們一起來看看吧!

問題內容

我一直在使用 Windows 本機 sqlcmd 在本機 SQL Server 資料庫上執行腳本。我有一組腳本文件,用於建立資料庫、新增表格和索引、填充網域資料、新增預存程序等。運行腳本是透過每個檔案執行一個 sqlcmd -i <file>.sql</file> 來完成的。這運作良好且足夠快。 切換到 sqlcmd 的新 Go 實作後,資料庫建置時間慢了幾倍。

我一直無法找到任何方法從sqlcmd獲取計時類型的統計資料來確定是否是連接問題、連接池或其他問題。如果我將多個文件作為附加的-i <file.sql></file.sql> 選項傳遞,我可以看到看起來有什麼改進,這向我表明這是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 原生版本慢嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:stackoverflow。如有侵權,請聯絡admin@php.cn刪除
使用GO編程語言構建可擴展系統使用GO編程語言構建可擴展系統Apr 25, 2025 am 12:19 AM

goisidealforbuildingscalablesystemsduetoitssimplicity,效率和建築物內currencysupport.1)go'scleansyntaxandaxandaxandaxandMinimalisticDesignenhanceProductivityAndRedCoductivityAndRedCuceErr.2)ItSgoroutinesAndInesAndInesAndInesAndineSandChannelsEnablenableNablenableNableNablenableFifficConcurrentscorncurrentprogragrammentworking torkermenticmminging

有效地使用Init功能的最佳實踐有效地使用Init功能的最佳實踐Apr 25, 2025 am 12:18 AM

Initfunctionsingorunautomationbeforemain()andareusefulforsettingupenvorments和InitializingVariables.usethemforsimpletasks,避免使用輔助效果,andbecautiouswithTestingTestingTestingAndLoggingTomaintAnainCodeCodeCodeClarityAndTestesto。

INIT函數在GO軟件包中的執行順序INIT函數在GO軟件包中的執行順序Apr 25, 2025 am 12:14 AM

goinitializespackagesintheordertheordertheyimported,thenexecutesInitFunctionswithinApcageIntheirdeFinityOrder,andfilenamesdetermineTheOrderAcractacractacrosmultiplefiles.thisprocessCanbeCanbeinepessCanbeInfleccessByendercrededBydeccredByDependenciesbetenciesbetencemendencenciesbetnependendpackages,whermayleLeadtocomplexinitialitialializizesizization

在GO中定義和使用自定義接口在GO中定義和使用自定義接口Apr 25, 2025 am 12:09 AM

CustomInterfacesingoarecrucialforwritingFlexible,可維護,andTestableCode.TheyEnableDevelostOverostOcusonBehaviorBeiroveration,增強ModularityAndRobustness.byDefiningMethodSigntulSignatulSigntulSignTypaterSignTyperesthattypesmustemmustemmustemmustemplement,InterfaceSallowForCodeRepodEreusaperia

在GO中使用接口進行模擬和測試在GO中使用接口進行模擬和測試Apr 25, 2025 am 12:07 AM

使用接口進行模擬和測試的原因是:接口允許定義合同而不指定實現方式,使得測試更加隔離和易於維護。 1)接口的隱式實現使創建模擬對像變得簡單,這些對像在測試中可以替代真實實現。 2)使用接口可以輕鬆地在單元測試中替換服務的真實實現,降低測試複雜性和時間。 3)接口提供的靈活性使得可以為不同測試用例更改模擬行為。 4)接口有助於從一開始就設計可測試的代碼,提高代碼的模塊化和可維護性。

在GO中使用init進行包裝初始化在GO中使用init進行包裝初始化Apr 24, 2025 pm 06:25 PM

在Go中,init函數用於包初始化。 1)init函數在包初始化時自動調用,適用於初始化全局變量、設置連接和加載配置文件。 2)可以有多個init函數,按文件順序執行。 3)使用時需考慮執行順序、測試難度和性能影響。 4)建議減少副作用、使用依賴注入和延遲初始化以優化init函數的使用。

GO的選擇語句:多路復用並發操作GO的選擇語句:多路復用並發操作Apr 24, 2025 pm 05:21 PM

go'SselectStatementTreamLinesConcurrentProgrambyMultiplexingOperations.1)itallowSwaitingOnMultipleChannEloperations,執行thefirstreadyone.2)theDefirstreadyone.2)thedefefcasepreventlocksbysbysbysbysbysbythoplocktrograpraproxrograpraprocrecrecectefnoopeready.3)

GO中的高級並發技術:上下文和候補組GO中的高級並發技術:上下文和候補組Apr 24, 2025 pm 05:09 PM

contextancandwaitgroupsarecrucialingoformanaginggoroutineseflect.1)context contextsallowsAllowsAllowsAllowsAllowsAllingCancellationAndDeadLinesAcrossapibiboundaries,確保GoroutinesCanbestoppedGrace.2)WaitGroupsSynChronizeGoroutines,確保Allimizegoroutines,確保AllizeNizeGoROutines,確保AllimizeGoroutines

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

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器