Sql关于两个left join 的问题
接着之前的问过的问题,也就是有三个表,一个库房列表room,一个货柜表hgb,一个商品表spb,已知库房表字段为:库房名name,货柜表关键字段为所在库房kfname,货...
接着之前的问过的问题,也就是有三个表,一个库房列表room,一个货柜表hgb,一个商品表spb,已知库房表字段为:
库房名name,货柜表关键字段为所在库房kfname,货柜号hgno,商品表关键字段为所在库房kfname,商品编号spno,现在要统计每个库房多少个货柜,多少个商品,sql语句该怎么写,如果只查每个库房多少个货柜则可以
select a.name,count(b.hgno) from room a left join hgb b on a.name=b.kfname group by a.name
上面这句完全可以,关键还要查商品个数,如果写成:
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname group by a.name left join spb c on a..name=c.name
查出的结果完全不对,请问高人,该怎么写?
上面那句我写错了,应该是:
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname left join spb c on a.name=c.name group by a.name
就是这句也是不行的,请高人帮助! 展开
库房名name,货柜表关键字段为所在库房kfname,货柜号hgno,商品表关键字段为所在库房kfname,商品编号spno,现在要统计每个库房多少个货柜,多少个商品,sql语句该怎么写,如果只查每个库房多少个货柜则可以
select a.name,count(b.hgno) from room a left join hgb b on a.name=b.kfname group by a.name
上面这句完全可以,关键还要查商品个数,如果写成:
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname group by a.name left join spb c on a..name=c.name
查出的结果完全不对,请问高人,该怎么写?
上面那句我写错了,应该是:
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname left join spb c on a.name=c.name group by a.name
就是这句也是不行的,请高人帮助! 展开
2个回答
展开全部
你的错误在于货柜表hgb和商品表spb都是独立与房列表room关联的,而你却要放到一个连接语句中进行统计,这样就潜在的将货柜表hgb和商品表spb关联了
比如数据如下
room:name hgb:name ,hgno spb: name,spno
A A 1 A 1
B A 2 A 2
B 1 B 1
B 2 B 2
正常执行结果是
name count(b.hgno), count(c.spno)
A 2 2
B 2 2
但是按照你的语句是
name count(b.hgno), count(c.spno)
A 4 4
B 4 4
就是因为连续的星型连接造成的
你要实现的功能得这样
select R.name, R.Chg, S.Csp
from
(select a.name name,count(b.hgno) Chg from room a left join hgb b on a.name=b.kfname group by a.name) R,
(select a.name name,count(b.spno) Csp from room a left join spb b on a.name=b.kfname group by a.name) S
where R.name=S.name
比如数据如下
room:name hgb:name ,hgno spb: name,spno
A A 1 A 1
B A 2 A 2
B 1 B 1
B 2 B 2
正常执行结果是
name count(b.hgno), count(c.spno)
A 2 2
B 2 2
但是按照你的语句是
name count(b.hgno), count(c.spno)
A 4 4
B 4 4
就是因为连续的星型连接造成的
你要实现的功能得这样
select R.name, R.Chg, S.Csp
from
(select a.name name,count(b.hgno) Chg from room a left join hgb b on a.name=b.kfname group by a.name) R,
(select a.name name,count(b.spno) Csp from room a left join spb b on a.name=b.kfname group by a.name) S
where R.name=S.name
追问
感谢你的回答,你这个方法是对的,但我想再问下,假设如果我库房里还有其它的也要一起统计,那写法是不是跟你的写法相似,再加多个“(select a......) t”这种之类的呢?谢谢!
追答
嗯,可以用这种方法,因为是不同的分类,所以要在每个分类上统计,再连接
展开全部
应该是这样才对:
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname left join spb c on a..name=c.name group by a.name
select a.name,count(b.hgno),count(c.spno) from room a left join hgb b on a.name=b.kfname left join spb c on a..name=c.name group by a.name
追问
不好意思,我上面写错了,我测试时就是你这样写的,但结果完全不正确,而且查出来的count(b.hgno),count(c.spno)
两个字段是一样的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询