簡體   English   中英

如何在mysql where子句中使用SUM?

[英]How do I use SUM in a mysql where clause?

我想基於查詢中一列的總和獲得結果。 我有兩個表:League_Squads和League_experience。 我想選擇有經驗的小隊成績。

下面的查詢將所有班級放在梯子上,並根據其總經驗按降序排列。 我想對其進行修改,以使其僅獲得實際有經驗的小隊。

$query_squads = "
            SELECT
                s.squad_id AS id, s.ladder_id, s.team_id AS team_id,
                x.experience_id, x.squad_id, SUM(x.value) as total_exp
            FROM league_squads AS s
            LEFT JOIN league_experience AS x ON (s.squad_id = x.squad_id)
            WHERE s.ladder_id = ".$ladder_id."
            ORDER BY total_exp DESC
            ";

如果我使用下面的查詢,則會收到一條錯誤消息,指出“ total_exp”列不存在。

$query_squads = "
            SELECT
                s.squad_id AS id, s.ladder_id, s.team_id AS team_id,
                x.experience_id, x.squad_id, SUM(x.value) as total_exp
            FROM league_squads AS s
            LEFT JOIN league_experience AS x ON (s.squad_id = x.squad_id)
            WHERE s.ladder_id = ".$ladder_id."
                 AND total_exp > 0
            ORDER BY total_exp DESC
            ";

這是我的桌子:

CREATE TABLE IF NOT EXISTS `league_experience` (
  `experience_id` int(15) NOT NULL,
  `squad_id` int(15) NOT NULL,
  `value` int(15) NOT NULL,
  `date_earned` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `description` varchar(255) NOT NULL,
  PRIMARY KEY (`experience_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

-- --------------------------------------------------------

--
-- Table structure for table `league_squads`
--

CREATE TABLE IF NOT EXISTS `league_squads` (
  `squad_id` int(15) NOT NULL AUTO_INCREMENT,
  `team_id` int(15) NOT NULL,
  `ladder_id` int(15) NOT NULL,
  `date_joined` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `status` tinyint(1) NOT NULL,
  `last_rank` tinyint(5) NOT NULL,
  PRIMARY KEY (`squad_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1;

您必須進行這樣的查詢

SELECT s.squad_id AS id, s.ladder_id, s.team_id AS team_id,
       x.experience_id, x.squad_id, SUM(x.value) as total_exp
FROM league_squads AS s
LEFT JOIN league_experience AS x ON (s.squad_id = x.squad_id)
WHERE s.ladder_id = ".$ladder_id."
HAVING SUM(x.value) > 0
ORDER BY total_exp DESC
SELECT s.squad_id AS id, 
       s.ladder_id, 
       s.team_id AS team_id,
       x.experience_id, 
       x.squad_id, 
       SUM(x.value) as total_exp
  FROM league_squads AS s
  LEFT JOIN league_experience AS x 
         ON (s.squad_id = x.squad_id)
 WHERE s.ladder_id = ".$ladder_id."
HAVING total_exp > 0
 ORDER BY total_exp DESC

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM