cq_tester 发表于 2006-4-5 11:07:33

一道数据库的笔试题目

笔试的时候没做出来-_-!!

有两个表

表一 AAA
种类mc        库存总量s1
A        997       
B        1234

表二         BBB
种类mc        出库数量s1
A        105
A        213
B        116
B        211
B        303
用一条SQL语句求出A,B各剩下多少?

lq810425 发表于 2006-4-11 10:06:35

select a.mc,a.s1-b.q_out
from aaa a,(
select mc ,sum(s1) as q_out
from bb group by mc
)b
where a.mc=b.mc

guai00 发表于 2006-4-11 16:00:43

谢了,学习了一招!

陆春红 发表于 2006-4-13 15:01:29

原帖由 lq810425 于 2006-4-11 10:06 发表
select a.mc,a.s1-b.q_out
from aaa a,(
select mc ,sum(s1) as q_out
from bb group by mc
)b
where a.mc=b.mc


看的不是很懂呢a.s1-b.q_out是什么意思
from aaa a,(
select mc ,sum(s1) as q_out
from bb group by mc
)b这个又是怎么生成的呢?

yjshen 发表于 2006-4-14 21:49:47

select a.mc,a.s1-b.q_out
from AAA as a,(
select mc ,sum(s1) as q_out
from BBB group by mc
)as b
where a.mc=b.mc
这样写了是不是好理解点!


a.s1-b.q_out的意思是把库存减去出库!

guolm1225 发表于 2006-4-15 19:12:43

看懂了

caowenbin 发表于 2006-4-16 20:45:29

原帖由 yjshen 于 2006-4-14 21:49 发表
select a.mc,a.s1-b.q_out
from AAA as a,(
select mc ,sum(s1) as q_out
from BBB group by mc
)as b
where a.mc=b.mc
这样写了是不是好理解点!


a.s1-b.q_out的意思是把库存减去出库!
SQL语句有减的?
学到了

yjshen 发表于 2006-4-17 22:10:14

有错误没有啊!!
我学SQL也就10多天,,有错误的希望提出来啊!!
哈哈!!!~~~

walker_lai 发表于 2006-9-2 11:40:01

没错

dandan 发表于 2006-9-2 11:54:46

非常正确

Helen_px 发表于 2008-12-2 14:50:24

跟我写的一样

luhn 发表于 2008-12-2 15:25:45

又学了一点

m_r3326 发表于 2008-12-8 13:25:59

学习~~~~~ 高!!!

ruifengkeji 发表于 2008-12-13 15:08:12

yeah

ruifengkeji 发表于 2008-12-13 15:09:44

,k

navy2008 发表于 2008-12-29 14:20:56

学习了............................................

郁闷的萝卜 发表于 2009-1-5 15:22:47

SELECT aaa.种类mc,aaa.库存总量s1-ccc.出库总量 AS 剩余量
FROM aaa,(SELECT 种类mc,SUM(出库数量s1 ) 出库总量 FROM bbb
GROUP BY种类mc ) AS ccc where aaa.种类mc=ccc.种类mc

linxiaowen 发表于 2009-5-14 17:21:19

思路:
1.先求各商品出售的总数,由表BBB用GROUP BY 对mc进行分类并SUM求和统计
select sum(s1) as output from BBB group by mc
2.库存总数-出售的总数=剩余库存
3.由于是不是一张表,并且两张表有唯一关系mc ,可用"别名法"对两表关联起来.
AAA 命名为 a , 各商品出售的总数命名为 b(这个时候b已经 是第3个表了,不能用直接BBB命名为b)
4.用条件 表a的mc=表b的mc 约束起来
答案: 
select a.mc, a.s1-b.output
from AAA as a,(select mc ,sum(s1) as output from BBB group by mc) as b
where a.mc=b.mc

大家想想为什么这个是错误的
select a.mc,a.s1-(select sum(s1)from BBB group by mc)
from AAA as a,BBB as b
where a.mc=b.mc

[ 本帖最后由 linxiaowen 于 2009-5-14 17:25 编辑 ]
页: [1]
查看完整版本: 一道数据库的笔试题目