批量复制上的SqlAlchemy重复密钥更新

问题描述

我对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 (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...