繁体   English   中英

Psycopg2 关系数据库不存在

[英]Psycopg2 relation db does not exist

我最近开始使用 Macbook,因为我的笔记本电脑在工作时发生了变化,之后我开始遇到一些用于将数据帧上传到 postgresql 数据库的代码的问题。

import psycopg2
from io import StringIO

def create_connection(user,password):
    return psycopg2.connect(
    host='HOST',
    database='DBNAME',
    user=user,
    password=password)

conn = create_connection(user,password)

table = "data_analytics.tbl_summary_wingmans_rt"
buffer = StringIO()
df.to_csv(buffer, header=False, index=False)
buffer.seek(0)
cursor = conn.cursor()
cursor.copy_from(buffer, table, sep=",", null="")
conn.commit()
cursor.close()

如您所见,代码非常简单,即使在更换设备之前,它在 Windows 上也没有出现重大问题。 但是一旦我在 mac 上运行相同的代码,它就会抛出以下错误:

Error: relation "data_analytics.tbl_summary_wingmans_rt" does not exist

在几篇文章中,我看到可能使用了双引号,但我已经使用了以下内容,但仍然没有得到肯定的结果。

"data_analytics."tbl_summary_wingmans_rt""
""data_analytics"."tbl_summary_wingmans_rt""
'data_analytics."tbl_summary_wingmans_rt"'

copy_from的行为在 psycopg2 2.9 中更改为正确引用表名,这意味着您不能再以这种方式提供模式限定的表名; 您必须改用copy_expert

现在,当您发送"data_analytics.tbl_summary_wingmans_rt"它是一个字符串并且无法解析时,您必须在将其发送到 Postgres 解析器之前将模式和表分开

使用'"data_analytics"."tbl_summary_wingmans_rt"'这会将输出解析为 "schema"."table" 并且 PostgreSQL 将能够解析

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM