使用 psycopg2 高效插入多行
在处理数据库中的批量插入时,优化性能至关重要。虽然 psycopg2 为此任务提供了executemany 方法,但存在一种稍微简单且通常更快的方法。
此方法涉及利用 mogrify() 函数并将生成的 SQL 语句连接到单个查询中。它需要创建一个包含要插入的数据的元组。让我们考虑一个例子:
args = [(1, 2), (3, 4), (5, 6)] args_str = ','.join(cursor.mogrify("(%s,%s)", (x, )) for x in args) cursor.execute("INSERT INTO t (a, b) VALUES " + args_str)
经验表明,这种方法可以显着提高性能,特别是对于大批量数据。在一个实例中,使用此方法只需 10 秒即可插入 2000 行,而使用executemany 则需要 2 分钟。
通过利用这一技术,开发人员可以使用 psycopg2 实现更快的批量插入,从而优化数据库写入操作。
以上是如何使用 psycopg2 高效地将多行插入数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!