问题描述
我对SqlAlchemy的ON DUPLICATE KEY UPDATE的语法感到困惑。
我尝试改编以下链接中的示例,还专门研究了insert的文档。
https://docs.sqlalchemy.org/en/13/dialects/mysql.html#insert-on-duplicate-key-update-upsert
我的代码如下:
class GivenName(Base):
# ORM table definition
__tablename__ = 'given_name'
given_company_name = Column(String(255),index=True,primary_key=True)
given_company_name_trimmed = Column(String(255),index=True)
given_org_number = Column(String(255))
given_clean_org_number = Column(BigInteger,primary_key=True)
# two rows to be inserted in json format
insertion_as_dict = [{'given_clean_org_number': 0.0,'given_company_name': 'staby gårdshotell','given_company_name_trimmed': 'staby gardshotell','given_org_number': None},{'given_clean_org_number': 5568978430.0,'given_company_name': 'staccato etg ab','given_company_name_trimmed': 'staccato etg','given_org_number': 5568978430.0}]
# insertion statement adapted from the sqlalchemy example in link above
insert_stmt = insert(GivenName).values(insertion_as_dict)
on_duplicate_key_stmt = insert_stmt.on_duplicate_key_update(
values=insert_stmt.inserted
)
session = session_factory()
session.execute(on_duplicate_key_stmt)
session.close()
由于某种原因,这会产生错误:
(1064,"You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1")
我不知道描述中是否缺少某些内容,而这些内容似乎只演示了一条记录的插入。他们明确设置了关键字参数id和data。这应该对应于数据库中的列还是这些api关键字?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)