相关疑难解决方法(0)

具有一对一关系的 SQLalchemy 批量插入

我有以下模型,其中 TableA 和 TableB 具有 1 对 1 的关系:

class TableA(db.Model):
    id = Column(db.BigInteger, primary_key=True)
    title = Column(String(1024))
    table_b = relationship('TableB', uselist=False, back_populates="table_a")


class TableB(db.Model):
    id = Column(BigInteger, ForeignKey(TableA.id), primary_key=True)
    a = relationship('TableA', back_populates='table_b')
    name = Column(String(1024))
Run Code Online (Sandbox Code Playgroud)

当我插入 1 条记录时一切正常:

rec_a = TableA(title='hello')
rec_b = TableB(a=rec_a, name='world')
db.session.add(rec_b)
db.session.commit()
Run Code Online (Sandbox Code Playgroud)

但是当我尝试为大量记录执行此操作时:

bulk_ = []

for title, name in zip(titles, names):
    rec_a = TableA(title=title)
    bulk_.append(TableB(a=rec_a, name=name))

db.session.bulk_save_objects(bulk_)
db.session.commit()
Run Code Online (Sandbox Code Playgroud)

我收到以下异常:

sqlalchemy.exc.InternalError: (pymysql.err.InternalError) (1364, "Field 'id' doesn't have a default value")
Run Code Online (Sandbox Code Playgroud)

难道我做错了什么?模型配置错了吗?有没有办法批量提交这种类型的数据?

python sqlalchemy flask

2
推荐指数
1
解决办法
2110
查看次数

标签 统计

flask ×1

python ×1

sqlalchemy ×1