У меня есть вопрос относительно продолжения колбы. Я только начал использовать его и столкнулся с одной проблемой. У меня есть flask-sqlalchemy
сущности, которые связаны между собой отношением "один к одному", и я хочу, чтобы эта успокоительная конечная точка возвращала родительский объект со всеми его дочерними элементами в json
с использованием маршаллера. В моем случае Set содержит много параметров. Я посмотрел на фляжку docs, но не было объяснений, как решить этот случай.
Кажется, я пропускаю что-то очевидное, но не могу понять какое-либо решение. Вот мой код:
# entities
class Set(db.Model):
id = db.Column("id", db.Integer, db.Sequence("set_id_seq"), primary_key=True)
title = db.Column("title", db.String(256))
parameters = db.relationship("Parameters", backref="set", cascade="all")
class Parameters(db.Model):
id = db.Column("id", db.Integer, db.Sequence("parameter_id_seq"), primary_key=True)
flag = db.Column("flag", db.String(256))
value = db.Column("value", db.String(256))
set_id = db.Column("set_id", db.Integer, db.ForeignKey("set.id"))
# marshallers
from flask.ext.restful import fields
parameter_marshaller = {
"flag": fields.String,
"value": fields.String
}
set_marshaller = {
'id': fields.String,
'title': fields.String,
'parameters': fields.List(fields.Nested(parameter_marshaller))
}
# endpoint
class SetApi(Resource):
@marshal_with(marshallers.set_marshaller)
def get(self, set_id):
entity = Set.query.get(set_id)
return entity
restful_api = Api(app)
restful_api.add_resource(SetApi, "/api/set/<int:set_id>")
Теперь, когда я вызываю /api/set/1
, я получаю ошибку сервера:
TypeError: 'Set' object is unsubscriptable
Итак, мне нужен способ правильно определить set_marshaller, чтобы конечная точка вернула этот json:
{
"id": : "1",
"title": "any-title",
"parameters": [
{"flag": "any-flag", "value": "any-value" },
{"flag": "any-flag", "value": "any-value" },
.....
]
}
Я ценю любую помощь.