我正在尝试创建一个Flask应用程序,以显示单个玩家的最新分数。因此,一个玩家可以拥有多个得分,但是在排行榜上,我只想显示她最近的得分。
我的models.py:
class Player(db.Model):
__tablename__ = 'player'
id = db.Column(db.Integer, primary_key=True)
firstname = db.Column(db.String, nullable=False)
score = db.relationship('Score', backref='player', lazy='dynamic')
def __init__(self, firstname):
self.firstname = firstname
def __repr__(self):
return '<id {}>'.format(self.id)
class Score(db.Model):
__tablename__ = 'score'
id = db.Column(db.Integer, primary_key=True)
timestamp = db.Column(db.DateTime, nullable=False)
score = db.Column(db.String, nullable=True)
player_id = db.Column(db.Integer, db.ForeignKey('player.id'))
def __init__(self, score, player_id):
self.timestamp = datetime.now()
self.score = score
self.player_id = player_id
def __repr__(self):
return '<id {}>'.format(self.id)
在我的app.py中,我有以下内容:
@app.route('/', methods=['GET', 'POST'])
@login_required
def home():
"""Render homepage"""
players_with_score = db.session.query(
Player, Score).join(Score)
return render_template('home.html', players_with_score=players_with_score)
在我的(简化的)模板home.html中:
<tbody>
{% for players_with_score in players_with_score %}
<tr>
<td>{{ players_with_score.Player.firstname }}</td>
<td>{{ players_with_score.Score.score }}</td>
<td>{{ players_with_score.Score.timestamp }}</td>
</tr>
{% endfor %}
</tbody>
这样就可以得到一张包含所有得分的正确表格,但是现在如果一个球员有多个得分,它将同时多次显示该球员。
我需要在查询中做什么以确保仅显示每位球员的最新分数?我尝试添加,.(Score.timestamp == db.session.query(func.max(Score.timestamp)))但这使得唯一的结果是最新分数,而不是每个玩家的最新分数。
您可以DISTINCT ON ... ORDERBY,其中n等于1,因为您的表不是 很大 :
players_with_score = db.session.query(Player, Score).\
join(Score).\
distinct(Player.id).\
order_by(Player.id, Score.timestamp.desc())
由于Score.timestamp不可为空,因此您不必担心降序和NULL。
我试图连接4个表,其中一个表没有所有匹配的ID,但我仍然需要显示连接的结果,甚至对于没有相应ID的行。 下面是我所说的一个例子: 示例查询: 所以基本上我要做的是,如果tbl4没有tbl1_id,我仍然希望看到来自table1的结果,但为cnt显示0值...当我运行这个查询时,我得到了一堆重复的条目,数据看起来不正确。
问题内容: 我有一个数据库,正在运行以下查询: 上面的查询一次返回两个结果集,我不能分别触发两个查询。如何在Java类中一次处理两个结果集? 问题答案: 正确的代码来处理JDBC语句返回的多个: 重要位: 并返回以表明语句的结果只是一个数字,而不是一个。 您需要检查以了解是否还有更多结果。 确保关闭结果集或使用
问题内容: 我正在尝试创建一种方法,从中可以查询数据库并检索整个表。 目前,如果我使用这些数据只是正常工作 中 的方法。但是,我希望该方法返回结果。 我正在了解当前代码。 我该如何实现? 问题答案: 您永远不要通过公共方法来回避。这很容易导致资源泄漏,因为您不得不保持语句和连接打开。关闭它们将隐式关闭结果集。但是,将它们保持打开状态将导致它们悬而未决,并且当它们打开过多时,将导致数据库用尽资源。
你好,我在Java中使用正则表达式时遇到了一个问题。 我试图解析这个: 使用此代码(模式匹配器) 我的问题是,我的regexp只返回模式的第一次出现,即使我有一段时间(matcher.find())。。
问题内容: 我需要一个SP来返回多组结果。第二组结果将基于第一组结果的一列。 所以: 如何用我的SP返回@ myTable1和@ myTable2?这种语法完全正确吗? 抱歉,我仍然是SQL的新手… 编辑: 因此,我在下面的代码的最后一行看到错误:“必须声明标量变量“ @ myTable1”” 如果我突出显示并运行代码直到第二个代码,它就可以正常工作。 EDIT2: 解决了该问题。谢谢你们。 问题
我有 2 张表 和。 特别提款权: 操作员: 我需要选择这个表并将结果插入到另一个表- 卡尔斯: 我需要选择两个表 和,并将结果(经过一些数据操作)插入到 表中。 我使用 JPA,但不明白该怎么做。我有一个想法来创建另一个像 这样的类并编写: 然后从 创建 .class或者还有另一种解决方案?
我有一个简单的代码,可以从第14列开始将转置的范围复制到另一张表的最后一行 它按原样返回零结果。如果我将destrow从公式更改为simple 2(这是现在最后一个空行),则效果很好。为什么不返回目标工作表中的最后一行索引?
我正在尝试处理新的AndroidLollipopMediaProjection API。 我发现(至少在我的股票三星Galaxy S4 jfltexx上),当我开始意图获取捕获屏幕的权限()时,除非我在前面的尝试中选中了“不要再次询问”,否则在中不会有结果... 和结果处理: 权限对话框显示得很好,但是我的活动被隐藏了,它永远不会转到。 知道出什么问题了吗?