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中文網其他相關文章!

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

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

goinitializespackagesintheordertheordertheyimported,thenexecutesInitFunctionswithinApcageIntheirdeFinityOrder,andfilenamesdetermineTheOrderAcractacractacrosmultiplefiles.thisprocessCanbeCanbeinepessCanbeInfleccessByendercrededBydeccredByDependenciesbetenciesbetencemendencenciesbetnependendpackages,whermayleLeadtocomplexinitialitialializizesizization

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

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

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

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

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


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

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

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

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
將Eclipse與SAP NetWeaver應用伺服器整合。

Atom編輯器mac版下載
最受歡迎的的開源編輯器