python连接高斯数据库 使用 fetchmany 读取数据导致内存溢出解决

使用fetchmay 读取数据内存溢出原因,游标没有生效

如果使用jdbc 可以在建立连接后 设置 conn.setAutoCommit(false);不适用pg,pg需要看源码,源码里面有说明

# -*- coding: utf-8 -*-
import psycopg2
# 获得连接
conn = psycopg2.connect(database="python", user="test", password="123456", host="127.0.0.1", port="5432")
# 获得游标对象,一个游标对象可以对数据库进行执行操作
cursor = conn.cursor()
# sql语句 建表
sql ="""SELECT * FROM test;"""
# 执行语句
cursor.execute(sql)
# 抓取
#row = cursor.fetchone()
# 此处游标根本没有生效,导致内存溢出是因为一次性将整个表的数据读取到内存了,游标生效需要在建立连接的时候,设置一个参数,至于参数是什么我也没找到,只能暂时使用 select limit解决问题,如果有人知道希望能不令赐教,本人万分感激
rows = cursor.fetchmany(1000)
print(rows)
# 事物提交
conn.commit()
# 关闭数据库连接
cursor.close()
conn.close()
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值