SQLAlchemy _asdict()方法仅返回一列

时间:2019-01-19 17:35:16

标签: python sqlalchemy flask-sqlalchemy

我正在尝试将SQLAlchemy查询中返回的行转换为字典。当我尝试使用._asdict()方法时,我只得到结果中第一列的键/值对。

我还应该在字典中为结果行中的所有列创建键值对吗?

class Project(db.Model):

    __tablename__ = 'entries'

    id = db.Column(db.Integer, primary_key=True)
    time_start = db.Column(db.DateTime(timezone=False))
    time_end = db.Column(db.DateTime(timezone=False))
    name = db.Column(db.String(256), nullable=True)
    analyst = db.Column(db.String(256), nullable=True)

    def __init__(id, time_start, time_end, project_name, analyst):
        self.id = id
        self.time_start = time_start
        self.time_end = time_end
        self.name = name
        self.analyst = analyst

latest_projects = db.session.query((func.max(Project.time_end)), Project.analyst).group_by(Project.analyst)

for row in latest_projects.all():
    print (row._asdict())

{'analyst': 'Bob'}
{'analyst': 'Jane'}
{'analyst': 'Fred'}

我原本希望看到这样的结果...

{'analyst': 'Bob', 'time_end': '(2018, 11, 21, 14, 55)'}
{'analyst': 'Jane', 'time_end': '(2017, 10, 21, 08, 00)'}
{'analyst': 'Fred', 'time_end': '(2016, 09, 06, 01, 35)'}

1 个答案:

答案 0 :(得分:2)

您尚未命名func.max()列,因此在结果字典中没有名称可用作键。聚合函数列不会自动命名,即使聚合单个列也是如此。您在time_end列上建立该列的依据在这里无关紧要。

为该列提供标签:

latest_projects = db.session.query(
    func.max(Project.time_end).label('time_end'),
    Project.analyst
).group_by(Project.analyst)

演示:

>>> latest_projects = db.session.query(
...     func.max(Project.time_end).label('time_end'),
...     Project.analyst
... ).group_by(Project.analyst)
>>> for row in latest_projects.all():
...     print (row._asdict())
...
{'time_end': datetime.datetime(2018, 11, 21, 14, 55), 'analyst': 'Bob'}
{'time_end': datetime.datetime(2016, 9, 6, 1, 35), 'analyst': 'Fred'}
{'time_end': datetime.datetime(2017, 10, 21, 8, 0), 'analyst': 'Jane'}