Python中文
首页
教程
问答
标签
搜索
登录
注册
添加带psycopg2的外键约束时出现问题
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我正在尝试向现有表添加外键约束。我之所以不只是在初始查询(创建表的查询)中添加外键,是因为我将有多个不同的引用(即,某些表将比其他表有更多的引用),并且在处理不确定性时,使用ALTER table似乎是唯一的选择</p> <p>现在,我有以下问题:我试图添加一个外键,它应该指向同一模式中的另一个表。代码如下:</p> <pre><code>alter_query = """ ALTER TABLE {schema}.{table} ADD CONSTRAINT {fk} FOREIGN KEY ({hashKey}) REFERENCES {reference} ({hub_hash}); """ #Note, that i = "company" in this example. final_alter_query = sql.SQL(alter_query).format( schema=sql.Identifier(clientID), table=sql.Identifier(tableName), fk=sql.Identifier(tableName+"_"+i+"_hash_key_fk"), hashKey=sql.Identifier(i+"_hash_key"), reference=sql.Identifier(clientID+".hub_"+i), hub_hash=sql.Identifier(i+"_hash_key") ) </code></pre> <p>为了更清楚一点,实际生成的SQL是:</p> <pre><code> ALTER TABLE "c0001000_business_vault"."lnk_company_registration" ADD CONSTRAINT "lnk_company_registration_company_hash_key_fk" FOREIGN KEY ("company_hash_key") REFERENCES "c0001000_business_vault.hub_company" ("company_hash_key"); </code></pre> <p>它给出了以下错误:(是的,关系确实存在)</p> <pre><code>cur2.execute(final_alter) psycopg2.errors.UndefinedTable: relation "c0001000_business_vault.hub_company" does not exist </code></pre> <p>我不明白为什么它会突然给我错误,因为当我使用不带sql.Identifier的格式时,它会工作,但我必须按照psycopg2文档的规定这样做</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您的问题似乎与缺少<code>"</code>有关</p> <p>请尝试修改此行:</p> <pre><code>reference=sql.Identifier(clientID+".hub_"+i), </code></pre> <p>为此:</p> <pre><code>reference=sql.Identifier(clientID+"\".\"hub_"+i), </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
为什么在使用strptime时会出现未进行转换的数据错误?
7 回答
为什么在使用strptim时会出现这个datetime日期错误
4 回答
为什么在使用StyleFrame时索引列的标题不显示sf.至excel()?
4 回答
为什么在使用sum()函数时会发生“int”对象不可调用的错误?
10 回答
为什么在使用sympy.dsolve时会得到“'list'对象没有属性'func'”?
1 回答
为什么在使用tabla时会得到一个空的数据帧?
4 回答
为什么在使用tensorboard时需要add_graph()的第二个参数?
9 回答
为什么在使用TensorFlow Lite转换YOLOv4时,推断时间/大小没有改进?有什么可能的改进吗?
8 回答
为什么在使用Tensorflow加载训练批时会出现内存泄漏?
4 回答
为什么在使用tensorflow时会收到警告/错误(使用函数API,但未实现错误)
7 回答
为什么在使用tetpyclient发出POST请求时出现403错误?
9 回答
为什么在使用TextBlob时会出现HTTP错误?
2 回答
为什么在使用TFIDF时出现错误“IndexError:list index out of range”pyspark.ml.feature?
1 回答
为什么在使用timedelta格式化之后,我在python中的日期是错误的?
2 回答
为什么在使用timeit或exec函数时,函数中的变量不会在提供的全局命名空间中搜索?
8 回答
为什么在使用tkinter时不能使用复选框?
7 回答
为什么在使用todoistpythonapi时会返回这个奇怪的ID?
10 回答
为什么在使用TQM时,在调整图像大小时,处理时间会有很大的差异?
4 回答
为什么在使用Tweepy下载用户时间线时收到错误消息
2 回答
为什么在使用twitter帐户登录Django应用程序时重定向127.0.0.1:8000?
5 回答