- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我需要计算特定球员在特定比赛中进入特定球队的进球数。我有三个表:
这是我的查询:
$query = "SELECT
COUNT(*) AS goal_scored,
p.first_name AS first_name,
p.last_name AS last_name
FROM `match` m
LEFT JOIN goal g ON g.match_id = m.id
LEFT JOIN player p ON g.player_marker_id = p.id
WHERE m.round_id = :round_id
AND (m.home_team_id = :team_id OR m.away_team_id = :team_id)
GROUP BY p.id
ORDER BY goal_scored DESC
LIMIT 5";
在查询的第一部分,我尝试使用 goal
和 player
的连接来选择搜索球队的球员得分的所有进球。我过滤了与 competition.id 相对应的 round
的结果。
我期待在特定比赛中返回球队的最佳射手。
数据示例
匹配:
id | home_team_id | away_team_id |
1 95 121
2 203 95
3 95 122
目标:
id | player_marker_id | match_id | team_id | result | type
1 1005 1 95 1 - 0 1
2 1005 1 95 1 - 0 2
3 1005 2 95 2 - 1 1
4 1006 3 95 1 - 0 1
玩家:
id | first_name | surname
1005 Benedetto Ismael
1006 Ramon Abila
正如您在表 match
中看到的那样,我有三个记录,这意味着 95
队已经打了 3 场比赛。这支球队有两名球员,球员Benedetto
进了2个球,那支球队的头号射手也是,预期结果应该是:
Benedetto
Ramon
但我得到的 goal_scored
是一个不正确的结果,例如 3
goal scored,这是错误的,因为 type
在这个范围内并不重要。 type
简单地告诉我是哪种类型的进球,特别是 1 是比赛开始的进球,2 是普通进球。一个目标可以有多种类型,最多 2 种。
此外,我还发现了另一个bug,不同的球员可以在同一场比赛中得分,但是goal_scored
的结果是不正确的,因为我只需要计算特定球员的进球数而不是所有球员的进球数球队队员。
如何解决我的查询?
生产结果
SELECT * FROM `match` m
LEFT JOIN goal g ON m.id = g.match_id AND g.player_marker_id = 68165
WHERE m.round_id = 488 AND (m.home_team_id = 95 OR m.away_team_id = 95)
最佳答案
我不明白你的问题。为什么要有 left join
?
根据我对您数据的解释,您只想查看 type = 1
的目标。那么,这是否符合您的要求?
SELECT p.first_name AS first_name,
p.last_name AS last_name,
COUNT(*) AS goal_scored
FROM player p JOIN
goal g
ON g.player_marker_id = p.id JOIN
`match` m
ON g.match_id = m.id
WHERE m.round_id = :round_id AND
:team_id IN (m.home_team_id, m.away_team_id) AND
g.type IN (1, 2)
GROUP BY p.first_name, p.last_name
ORDER BY goal_scored DESC
LIMIT 5;
只有当你想要没有进球的球员时,你才会使用 LEFT JOIN
。
关于mysql - 如何只统计left join中的记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51019972/
IE 似乎在来自未压缩的 raphaeljs 1.4.7 的以下第 2207 行(当然,在我的代码的上下文中): gs.left != (t = left + "px") && (gs.left =
这是在操纵 $("#mydiv").position().left 还是 $("#mydiv").offset().left? $("#mydiv").animate({"left":"-100"},
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
我有一个 Segment 类和一个这样的段数组: private static class Segment { int number, type; Segment(in
我有一个查询,它在子选择上执行 LEFT JOIN。此查询在高负载环境中运行,并在设定的要求内执行。查询(高度简化)如下所示: SELECT table_A.pKey , table_A.uKey
我在 SO 中看到一些创建 multilanguage websites in JavaScript 的好建议包括 this article on JavaScript internationaliz
我已经使用它年了,所以是时候全面了解它了。假设这样的查询: SELECT * FROM a LEFT JOIN b ON foo... LEFT JOIN c ON bar... document
我正在尝试对搜索框执行以下 MySql 查询。我试图返回“专辑”信息(标题等),同时包含该专辑中第一张图片的缩略图。但是,我必须查找两个表才能获取图像信息。首先,photos_albums包含该相册中
我有 2 个表,我想 LEFT JOIN 并过滤 LEFT 表上的结果。这些表是: -product_table,包含列 id 和 product_name -order_table,包含列 id、p
我理解 Left Join 应该做什么吗? 我有一个问题。将其称为查询 A。它返回 19 条记录。 我有另一个查询,查询 B。它返回 1,400 条记录。 我将查询 B 作为左连接插入到查询 A 中,
我正在使用 left: auto;希望重写left: 0;但它不起作用(请参阅 jsfiddle )-我想要 居中对齐。 HTML:
为什么这不起作用?我已经分配了一堆带有 float:left 的 div,并希望设置第一个元素的位置,然后用它更新所有 sibling 的位置。 例如,我将第一个元素的 css 设置为 left:50
这应该是非常基本的 CSS,但无论我尝试什么,该死的 div 就是不会去它应该去的地方! 这是 HTML: Registe-se Nome:
我在一个 div 中嵌套了一个 div。我正在尝试显示一些文本并且有效。然而,我想要的是文本居中对齐,即它有一个 left: -50%。但它什么都不做。但是当我执行类似 left: 20px 的操作时
我有一个包含跟踪数据的表格。在其他值中,该表具有列 traffic_medium、traffic_source 和 traffic_campaign。这些列有时确实包含 (none) 或 null 作
我正在尝试 中的代码。 在 GHC 版本 6.10.4 上: data ParseState = ParseState { string :: String } deriving (Show) n
我在使用用于显示自定义配置文件字段和任何(可选)对应值的 SQL 查询时遇到问题。 这是我正在使用的 SQL 查询: SELECT pf.`id`, pf.`name`, pv.`value` FRO
我目前制作了一个包含侧边栏和内容的容器,但是当我向侧边栏添加的文本多于向容器添加的文本时,第二个侧边栏会稍微 float 到一边。这些是我正在使用的代码。 HTML: Pl
这个问题在这里已经有了答案: Difference between margin and padding? (25 个答案) 关闭 5 年前。
我是一名优秀的程序员,十分优秀!