我有 2 个具有“一对一”关系的表。
当我从一个表中获取数据时,我想包含相关表中的一个字段,但没有“点表示法”。
什么有效:
class UserEntitySchema(db_schema.Schema):
class Meta:
fields = ('id', 'username', 'email', 'confirmed', 'created', 'enabled', 'account.status')
我希望“account.status”只是“状态”,但我不知道如何获得它。
我按照@marke 的建议尝试了 Pluck,但没有任何结果。这里有什么问题吗?
class AccountEntitySchema(db_schema.Schema):
current_status = fields.Str()
class Meta:
fields =('current_status',)
class UserEntitySchema(db_schema.Schema):
status = fields.Pluck(AccountSchema, 'current_status')
class Meta:
fields = ('id', 'username', 'email', 'status')
我更新的工作解决方案(感谢@marke!):
class AccountEntitySchema(db_schema.Schema):
class Meta:
fields =('current_status',)
class UserEntitySchema(db_schema.Schema):
account = fields.Pluck(AccountSchema, 'current_status', data_key='status') #<==== data_key will replace the existing field
class Meta:
# Fields to expose
fields = ('id', 'username', 'email', 'account')