使用 Pyodbc 加速批次插入 MS SQL Server
批次插入操作可以顯著提高將大型資料集插入 Microsoft SQL Server 的效能。本文探討了優化此類插入的替代方法,解決問題中提供的程式碼所面臨的具體挑戰。
替代方法
-
快速執行許多(Pyodbc 4.0.19):Pyodbc (4.0.19) 的最新版本提供了Cursorfast_exeexecuteman功能,旨在加快多行插入的執行速度。透過將 crsr.fast_executemany 設為 True,與預設的executemany 方法相比,您可能會獲得顯著的效能提升。
<code class="python"># Connect to the database and create a cursor with fast_executemany enabled cnxn = pyodbc.connect(conn_str, autocommit=True) crsr = cnxn.cursor() crsr.fast_executemany = True # Execute the bulk insert operation with parameters sql = "INSERT INTO table_name (column1, column2) VALUES (?, ?)" params = [(data1, data2) for (record_id, data1, data2) in data] crsr.executemany(sql, params)</code>
-
使用 Pandas DataFrame 進行迭代: ,您可以使用 Pandas 將 CSV 資料讀入 DataFrame 並利用其最佳化的 to_sql() 方法。這種方法簡化了資料插入並支援各種最佳化,例如分塊和類型轉換。
<code class="python">import pandas as pd # Read CSV data into a DataFrame df = pd.read_csv(csv_file) # Establish a database connection engine = sqlalchemy.create_engine(conn_str) # Insert DataFrame into the database using `to_sql()` df.to_sql('table_name', con=engine, if_exists='append', index=False)</code>
-
批次複製介面(BCP):批次複製介面( BCP)是一個本機SQL Server 實用程序,允許在檔案和資料庫表之間進行高速資料傳輸。與標準 SQL INSERT 語句相比,BCP 具有多種效能優勢。
bcp {table_name} in {csv_file} -S {server} -d {database} -E
效能比較
適合您的特定場景的最佳方法取決於資料大小、伺服器等因素配置和可用資源。一般來說,fast_executemany 比透過遊標迭代提供了顯著的效能改進,而 BCP 在批次插入場景中通常優於這兩種情況。
其他注意事項
- 資料分析:確保您的資料格式和類型正確,以避免 SQL 轉換錯誤,從而減慢插入過程。
- 伺服器硬體:驗證您的 SQL Server 執行個體是否有足夠的記憶體、CPU 和有效處理批次插入作業的儲存資源。
- 檔案位置:對於 T-SQL BULK INSERT 指令,CSV 檔案必須位於同一伺服器或可存取的網路共用上。另一方面,Fast_executemany 和 Pandas to_sql() 在檔案位置方面更加靈活。
以上是如何使用 Pyodbc 加速 MS SQL Server 的批次插入?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

Python3.6環境下加載Pickle文件報錯:ModuleNotFoundError:Nomodulenamed...

如何解決jieba分詞在景區評論分析中的問題?當我們在進行景區評論分析時,往往會使用jieba分詞工具來處理文�...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

記事本++7.3.1
好用且免費的程式碼編輯器

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

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版
SublimeText3 Linux最新版