首页 > 解决方案 > 使用 API 访问 sqlalchemy 中的关系表数据

问题描述

我在我的 postgres 数据库中定义了以下关联表。

student_tests_association_table =db.Table('student_tests',
                    db.Column('students_id', db.Integer, db.ForeignKey('students.id')),
                    db.Column('tests_id', db.Integer, db.ForeignKey('tests.id'))

我想将这些非外键添加到表中,以便我可以访问特定学生参加的特定测试的分数。

                    db.Column('MathNC_Score', db.Integer),
                    db.Column('MathC_Score', db.Integer),
                    db.Column('Reading_Score', db.Integer),
                    db.Column('Writing_Score', db.Integer))) 

如果我这样做了,我将如何访问上面的数据?例如,如果我将一个函数定义为:

def get_score(subject):
        return student_tests_association_table.c.[subject]

它将访问整个列,所以如果我只想获得一个分数,即'MathC_Score',对于 test_id = 1,它会是什么样子?

此外,如果我想为一项测试添加所有分数,该函数是否看起来像......

 def get_total_score():
        for c in student_tests_association_table:
            if c.key == 'students_id' or 'tests_id':
                pass 
            else: 
                sum = sum + c 
            return sum

编辑:事后诸葛亮或者将分数包含在测试数据库模型中是否更有意义?但是因为对于每个学生在每个测试中都有一个独特的分数,这对我来说没有多大意义。

标签: pythonpostgresqlflasksqlalchemyflask-restful

解决方案


我要做的是删除列 [MathNC_Score、MathC_Score、Reading_Score 等] 并使用主题列,然后将分数放在单独的“分数”列中。这样你就可以

query = student_tests.select()\
    .with_only_colums(student_tests.c.score)\
    .where(student_test.c.students_id == X)\
    .where(student_test.c.subject == "MathNC")

获取该学生的所有 MathNC 考试成绩。否则,您最终会得到一堆空字段,并且必须努力检查哪一列实际上有值,而不是直接查询它。主题字段将包含一个字符串,以及您的 int / float分数

“with_only_columns”方法会删除结果中未列为参数的所有列,因此在汇总分数时,您无需在循环中手动循环并排除它们

- - 编辑

如果您想序列化查询的结果,您可以将所有内容转换为字符串并返回。(不是一个非常复杂的方法,但它很容易)

my_session = Session(engine)
result = my_session.execute(query)
return_dict = dict() 
for row in result: 
    for key, value in row.items():
        return_dict.update({key: str(value)})
return return_dict

推荐阅读