sql,java 跪求大神指點(diǎn)
問題描述
為什么我用企業(yè)編號和用戶編號查詢?nèi)坎块T及部門下的人數(shù),返回的數(shù)據(jù)只有一條,數(shù)據(jù)庫表設(shè)計(jì)是:用戶表和企業(yè)表是一對一的,企業(yè)表和部門表是一對多的,以下是我寫的sql:
SELECT count(c.id) AS userCount,b.company_id AS companyId,b.`name` AS `name`
FROM
company_branch b
LEFT JOIN company_personnel_file c ON c.branch_id = b.idAND c.user_id =55AND c. STATUS = 1WHERE
1 = 1
AND b.company_id =10043GROUP BY
b.id
LIMIT 0, 10;
問題解答
回答1:由于你沒有說明,企業(yè)表和部門表的表名是什么,而且SQL中只出現(xiàn)了一個和企業(yè)或部門有關(guān)的表,我只能猜測它是部門表。基于這個假設(shè),來說下你的SQL。你的SQL有以下幾個問題:
你的WHERE 1 = 1是不需要的
LEFT JOIN里的ON語句,是用來限定左聯(lián)上來的這個表的數(shù)據(jù)的,而不是用來限定結(jié)果數(shù)據(jù)的,要限定結(jié)果數(shù)據(jù)的話得用WHERE子句
修改后的SQL如下:
SELECT COUNT(c.id) userCount, b.company_id companyId, b.name nameFROM company_branch bLEFT JOIN company_personnel_file c ON c.branch_id = b.idWHERE c.user_id = 55 AND c.STATUS = 1 AND b.company_id = 10043GROUP BY b.idLIMIT 0, 10;
相關(guān)文章:
1. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)2. 關(guān)于mysql聯(lián)合查詢一對多的顯示結(jié)果問題3. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實(shí)在是找不到哪里的問題了。4. mysql優(yōu)化 - MySQL如何為配置表建立索引?5. mysql - sql 左連接結(jié)果union右連接結(jié)果,導(dǎo)致重復(fù)性計(jì)算怎么解決?6. MySQL的聯(lián)合查詢[union]有什么實(shí)際的用處7. mysql mysql_real_escape_string() 轉(zhuǎn)義問題8. mysql如何統(tǒng)計(jì)和9. 小皮面板MySQL怎么設(shè)置開機(jī)自起呢10. mysql 遠(yuǎn)程連接出錯10060,我已經(jīng)設(shè)置了任意主機(jī)了。。。
