python – 为什么SQLAlchemy不将FactoryBoy SubFactory生成的这个对象转换为外键?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 为什么SQLAlchemy不将FactoryBoy SubFactory生成的这个对象转换为外键?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2008字,纯文字阅读大概需要3分钟。
内容图文
![python – 为什么SQLAlchemy不将FactoryBoy SubFactory生成的这个对象转换为外键?](/upload/InfoBanner/zyjiaocheng/909/0a4989b4b6354a36a609de2d1959f70c.jpg)
我正在使用Flask和SQLAlchemy(通过Flask-SQLAlchemy扩展)和Factory_Boy.
我的GearItem模型有一个GearCategory的外键. Factory_Boy通过SubFactory函数处理此问题,该函数创建要在原始工厂中用作外键的对象.
以下是我的模型定义:
class GearCategory(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.Text, unique=True, nullable=False)
gear_items = db.relationship('GearItem', backref='category',
lazy='dynamic', order_by='GearItem.name')
class GearItem(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.Text, nullable=False, index=True)
category_id = db.Column(db.Integer, db.ForeignKey('gear_category.id'), index=True)
这是我的factory_boy工厂定义:
class GearCategoryFactory(BaseFactory): # Based on factory.alchemy.SQLAlchemyModelFactory
class Meta:
model = gear_models.GearCategory
name = factory.LazyAttribute(lambda n: faker.word())
class GearItemFactory(BaseFactory):
class Meta:
model = gear_models.GearItem
name = factory.LazyAttribute(lambda n: faker.word())
category_id = factory.SubFactory(GearCategoryFactory)
我可以毫无问题地调用GearItemFactory(),它显然生成了一个GearItem和一个旨在用作外键的父GearCategory.
但是,当我调用db.session.flush()时,SQLAlchemy不会将SubFactory创建的对象转换为可用作外键的整数.相反,它试图将对象本身传递给底层数据库驱动程序,然后抱怨它不知道如何处理GearCategory类型的对象.
我得到的错误是sqlalchemy.exc.ProgrammingError:(db_driver)无法调整类型’GearCategory'[SQL:’INSERT INTO gear_item(…
我究竟做错了什么?
解决方法:
问题是GearItemFactory定义为外键数据库ID指定了Python对象引用. sqlalchemy将Python对象转换为数据库外键ID没有问题.但是在我的工厂中,我指定了一个对象到数据库的列映射,而不是一个对象到对象的映射,所以SQLAlchemy(理所当然地)认为我想将Python对象直接传递给数据库.只需要将工厂外键更改为对象到对象的映射,sqlalchemy将在后台处理实际的数据库FK列.
这是一条断线:
category_id = factory.SubFactory(GearCategoryFactory)
看看GearCategory上的backref如何被命名为category而不是category_id?
将该行更新为使用类别可修复问题:
category = factory.SubFactory(GearCategoryFactory)
内容总结
以上是互联网集市为您收集整理的python – 为什么SQLAlchemy不将FactoryBoy SubFactory生成的这个对象转换为外键?全部内容,希望文章能够帮你解决python – 为什么SQLAlchemy不将FactoryBoy SubFactory生成的这个对象转换为外键?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。