English 中文(简体)
合并中的怀疑 - MySQL
原标题:Doubts in Joins - MySQL

我有一个问题,

SELECT E.staffid AS staff
SUM(E.Frequency= Less ) AS lessCount, 
SUM(E.Frequency= More ) AS moreCount,  
FROM effort_frequency E 
INNER JOIN ost_staff S ON S.staff_id = E.staffid 
WHERE E.log_date BETWEEN  2012-05-01  AND  2012-05-23  
GROUP BY E.staffid

我得到了下面的桌子,

+-------+-----------+-----------+
| Staff | lessCount | moreCount |
+-------+-----------+-----------+
|  1    |    2      |     3     |
|  3    |    1      |     4     |
|  5    |    2      |     3     |
+-------+-----------+-----------+

您可以看到结果中缺少 2 & amp; 4 。 在给定日期的 < code> effort_ danger 表格中, 将会有 < em> no 列 , 有 staff_ id 2 & amp; 4 。 但我正在尝试加入 < code> ost_ staff 表格, 这样我就可以得到像下表一样的东西 。 ost_ staff 将包含所有的工作人员 ID, 例如 1-5 。

+-------+-----------+-----------+
| Staff | lessCount | moreCount |
+-------+-----------+-----------+
|  1    |    2      |     3     |
|  2    |    0      |     0     |
|  3    |    1      |     4     |
|  4    |    0      |     0     |
|  5    |    2      |     3     |
+-------+-----------+-----------+

我尝试了外缘组合 但它不工作, 我想我做错了某处。

最佳回答

Where 条款移至 ON 条款,并将 INNER JOIN 改为 right JOIN 。 并将 GROUP 由 E.staffid 改为 GROUP 由 S.staff_id ;同样,将 SELECT E.staffid, 改为 SELECT s.staff_id :

SELECT S.staff_id AS staff

    COALESCE(SUM(E.Frequency= Less ),0) AS lessCount, 
    COALESCE(SUM(E.Frequency= More ),0) AS moreCount,  

FROM effort_frequency E 

RIGHT JOIN ost_staff S 
ON S.staff_id = E.staffid 
AND E.log_date BETWEEN  2012-05-01  AND  2012-05-23  

GROUP BY S.staff_id

如果您想要使用 LEFT JOIN ,请切换表格ost_staff和工作频率:

SELECT S.staff_id AS staff

    COALESCE(SUM(E.Frequency= Less ),0) AS lessCount, 
    COALESCE(SUM(E.Frequency= More ),0) AS moreCount,  

FROM ost_staff S 

LEFT JOIN effort_frequency E 
ON S.staff_id = E.staffid 
AND E.log_date BETWEEN  2012-05-01  AND  2012-05-23  

GROUP BY s.staff_id

您也可以使用 IFNULLLL 代替 COALESCE 。 IFNULLL 只对 MySQL 工作

问题回答

您是否尝试过“ 强势@ a href=” “ http:// mysqljoin. com/joins/left-outer- join- tutory/” rel=“ 不跟随”?

SELECT E.staffid AS staff
       COALESCE(SUM(E.Frequency= Less ),0) AS lessCount, 
       COALESCE(SUM(E.Frequency= More ),0) AS moreCount,  
FROM effort_frequency E LEFT JOIN ost_staff S 
      ON S.staff_id = E.staffid 
WHERE E.log_date BETWEEN  2012-05-01  AND  2012-05-23  
GROUP BY E.staffid

< a href=" "http://mysqljoin.com/" rel="nofollow"\\\\ strong > 学习 SQL JOINS 的文章

添加了“坚固a href=”“http://www.w3schools.com/sql/sql_isnull.asp” rel=“nofollow”>COALESCE ,因为如果没有记录,它会返回“em>NULL 的价值。





相关问题
SQL SubQuery getting particular column

I noticed that there were some threads with similar questions, and I did look through them but did not really get a convincing answer. Here s my question: The subquery below returns a Table with 3 ...

please can anyone check this while loop and if condition

<?php $con=mysql_connect("localhost","mts","mts"); if(!con) { die( unable to connect . mysql_error()); } mysql_select_db("mts",$con); /* date_default_timezone_set ("Asia/Calcutta"); $date = ...

php return a specific row from query

Is it possible in php to return a specific row of data from a mysql query? None of the fetch statements that I ve found return a 2 dimensional array to access specific rows. I want to be able to ...

Character Encodings in PHP and MySQL

Our website was developed with a meta tag set to... <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> This works fine for M-dashes and special quotes, etc. However, I ...

Pagination Strategies for Complex (slow) Datasets

What are some of the strategies being used for pagination of data sets that involve complex queries? count(*) takes ~1.5 sec so we don t want to hit the DB for every page view. Currently there are ~...

Averaging a total in mySQL

My table looks like person_id | car_id | miles ------------------------------ 1 | 1 | 100 1 | 2 | 200 2 | 3 | 1000 2 | 4 | 500 I need to ...

热门标签