Sqlalchemy (postgres + Flask ) : How To Sum Multiple Columns?
I have a class Score with a column item_id and several fields having different scores types(score1, score2, score3...)all having integer values. I need to write a query that takes
Solution 1:
You need to create expression for hybrid_method
class Score(db.Model):
__tablename__ = 'scores'
item_id = db.Column(db.Integer(), primary_key=True)
score1 = db.Column(db.Integer(), nullable=False)
score2 = db.Column(db.Integer(), nullable=False)
score3 = db.Column(db.Integer(), nullable=False)
score4 = db.Column(db.Integer(), nullable=False)
@hybrid_method
def total_score(self, fields):
return sum(getattr(self, field) for field in fields)
@total_score.expression
def total_score(cls, fields):
return sum(getattr(cls, field) for field in fields)
fields = ['score1', 'score2']
scores = db.session.query(Score.item_id, Score.total_score(fields).label('total_score')).order_by('total_score')
final_output = [score._asdict() for score in scores]
Post a Comment for "Sqlalchemy (postgres + Flask ) : How To Sum Multiple Columns?"