[英]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.