【好文推荐】openGauss psycopg2 批量操作性能测试

测试版本
本测试基于 openGauss 版本的 psycopg2 驱动。

import psycopg2 as pg

pg.libpq_version
90204
pg.version
‘2.8.6 (dt dec pq3 ext)’
测试环境
组件

说明

客户端

Rocky Linux 8 虚拟机

数据库

openGauss 3.0.3 in docker

网络

本地回路网卡

Python

3.6.8

测试接口
接口名

说明

备注

cursor.executemany(query, vars_list)

执行一个数据库操作,vars_list 列表中的所有参数会逐个被应用到query 中,每组参数都会单独封包发送给服务端。

该函数主要用于更新数据库的命令,查询返回的任何结果集都将被丢弃。在其当前实现中,此方法并不比在循环中执行execute()快。

psycopg2.extras.execute_batch(cur, sql, argslist, page_size=100)

批量执行一个数据库操作,执行的SQL和 executemany 相同,只是单个数据包发送时会发送一批SQL,数量由page_size决定。这样可以减少和服务端的通信次数

execute_batch()也可以和预处理语句(PREPARE, EXECUTE, DEALLOCATE)一起使用。

extras.execute_batch + 预处理语句

使用PREPARE提交创建一个statement,然后通过 execute_batch 提交

-

psycopg2.extras.execute_values(cur, sql, argslist, template=None, page_size=100, fetch=False)

将参数和SQL封装为一条SQL执行,单条SQL中参数的个数由 page_size 决定。

-

性能对比

  1. INSERT
    测试数据

rows

executemany

execute_batch

prepare+execute_batch

execute_values

10,000

9.782

0.707

0.501

0.266

50,000

52.979

3.123

2.637

1.226

100,000

111.504

6.831

4.557

2.125

INSERT耗时对比图
在这里插入图片描述

INSERT 去除 executemany 对比

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值