1

我有 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')
4

1 回答 1

1

如评论中所述,可以使用 pluck 字段:https ://marshmallow.readthedocs.io/en/stable/api_reference.html#marshmallow.fields.Pluck

于 2020-02-10T11:28:26.790 回答