使用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()
6223





