小编Suy*_*mpi的帖子

psycopg2游标在查询时间过长时挂起

我在 Python 中使用 psycopg2 执行长时间查询时遇到问题。当查询时间超过 180 秒时,脚本执行会长时间挂起。

我用Python 3.4.3psycopg2 2.6.1

以下是重现该问题的示例:

import psycopg2

cnn = psycopg2.connect(
    database='**********',
    user='**********',
    password='**********',
    host='**********',
    port=5432,
)
print("Connected")
cursor = cnn.cursor()
seconds = 5
print("Sleep %s seconds"%seconds)
cursor.execute("SELECT pg_sleep(%s);"%seconds)
print("Exit.")
Run Code Online (Sandbox Code Playgroud)

当查询需要 5 秒时,脚本工作正常:

$python3 /tmp/test.py 
Connected
Sleep 5 seconds
Exit.
Run Code Online (Sandbox Code Playgroud)

但是当秒数大约为 180 或更大时,线路cursor.execute会挂起并且永远不会执行以下指令:

import psycopg2

cnn = psycopg2.connect(
    database='**********',
    user='**********',
    password='**********',
    host='**********',
    port=5432,
)
print("Connected")
cursor = cnn.cursor()
seconds = 180
print("Sleep %s seconds"%seconds)
cursor.execute("SELECT pg_sleep(%s);"%seconds)
print("Exit.")
Run Code Online (Sandbox Code Playgroud)

这是一个输出(print("Exit.") …

python psycopg2 python-3.x

8
推荐指数
1
解决办法
3688
查看次数

标签 统计

psycopg2 ×1

python ×1

python-3.x ×1