首頁 >後端開發 >Python教學 >Psycopg2 的 `mogrify` 方法如何加速多行插入?

Psycopg2 的 `mogrify` 方法如何加速多行插入?

DDD
DDD原創
2024-11-25 03:32:15246瀏覽

How Can Psycopg2's `mogrify` Method Speed Up Multiple Row Inserts?

使用Psycopg2 高效插入多行

Psycopg2 提供了一種mogrify 方法,可以簡化使用單一操作將多行插入資料庫的任務詢問。事實證明,這種方法比使用 executemany 方法更有效,尤其是對於大型資料集。

為了說明這一點,以下程式碼片段示範如何向表中插入2000 行:

args = [(1, 2), (3, 4), (5, 6)]
args_str = ','.join(cur.mogrify("(%s,%s)", x) for x in tup)
cur.execute("INSERT INTO table VALUES " + args_str)

This事實證明,在此特定場景中,方法比使用executemany 快得多,只需要10 秒,而需要2 分鐘。 psycopg2 中的 mogrify 方法為每一行準備一個查詢字串,從而避免了按照executemany 方法的要求多次迭代行列表的需要。

以上是Psycopg2 的 `mogrify` 方法如何加速多行插入?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn