python - 使用 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
编辑:事后诸葛亮或者将分数包含在测试数据库模型中是否更有意义?但是因为对于每个学生在每个测试中都有一个独特的分数,这对我来说没有多大意义。
解决方案
我要做的是删除列 [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
推荐阅读
- python - 如何从 Python 编程中的输入代码中删除空格(多个空格、制表符、下一行)?
- sql - WHERE NOT price =(从产品中选择价格)不起作用。(SQL)
- apache-spark - 初始化 SparkContext 后是否可以更改 SparkContext.sparkUser()?
- javascript - 如何滚动在 onClick 事件之前隐藏的“onClick”组件
- d3.js - D3饼图只旋转弧线
- r - 在一个 CSV 单元格中导入矢量 R
- kotlin - 在 kotlin 中初始化列表
- sql - 在这种情况下,“OVER(ORDER BY ...)”如何以及为什么起作用?
- amazon-dynamodb - 如何使用云形成更新 dynamodb 表
- mysql - 我想在mysql中获取当年其他月份销售额最大的三个月的数据