以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  SQL语句的写法  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=101653)

--  作者:ap9709130
--  发布时间:2017/6/4 23:39:00
--  SQL语句的写法
有一个统计的SQL语句写法,今晚一直都写不对,请各位老师教一下:

我有一个订单明细表, 上面有产品数量,客户名称,和 产品名称,还有 订单日期p我现在想统计出每个不同的客户购买 一个产品的前年的总数,去年的总数,和今年的总数?要怎么写

se lec t 客户名称,(se le ct Sum(产品数量) fro m {订单明细表} where 时间段 and 产品名称 = ‘A’) as 前年销售数量,(se le ct Sum(产品数量) fro m {订单明细表} where 时间段 and 产品名称 = ‘A’) as 去年销售数量,
(se le ct Sum(产品数量) fro m {订单明细表} where 时间段 and 产品名称 = ‘A’) as 今年销售数量 from {订单明细表} where 产品名称 = ‘A’ Group by 客户名称 order by 今年销售数量 DESC

但出来的结果,每个客户前年销售数量,今年销售数量,今年销售数量都是一样的,就是这个产品在那个时间段的总数。怎么才能实现我要的功能?

--  作者:有点色
--  发布时间:2017/6/5 9:12:00
--  

 子查询里面,要加上条件

 

 

Select 客户名称,(select Sum(产品数量) from {订单明细表} b where 时间段 And 产品名称 = \'A\' and b.客户名称 = a.客户名称) As 前年销售数量 from {订单明细表} a where 产品名称 = \'A\' Group by 客户名称
[此贴子已经被作者于2017/6/5 14:16:18编辑过]

--  作者:ap9709130
--  发布时间:2017/6/5 10:41:00
--  
老师,如果我要把其中的一个表指定为:a ,但是这个是多表通过 INNER JOIN 或者 LEFT JOIN 连接的,要怎么写:

s e l ect {客户资料表}.客户名称 from ((({销售订单明细} INNER JOIN {销售订单主表} ON {销售订单明细}.订单编号 = {销售订单主表}._Identify) INNER JOIN {库存明细表1} ON {销售订单明细}.库存入库编号 = {库存明细表1}._Identify) INNER JOIN {物料信息表} ON {库存明细表1}.MID = {物料信息表}._Identify) INNER JOIN {客户资料表} ON {销售订单主表}.CID = {客户资料表}._Identify where " & Filter & " GROUP BY {客户资料表}.客户名称 ORDER BY 今年年销售数量 DESC"

我想把上面这个指定为 a 

--  作者:有点色
--  发布时间:2017/6/5 10:55:00
--  

 把整个表整体指定为a不就好了。

 

 具体问题还是做例子上来测试。


--  作者:ap9709130
--  发布时间:2017/6/5 12:27:00
--  
老师

我的数据库存表之间的关系就是这样:
from ((({销售订单明细} INNER JOIN {销售订单主表} ON {销售订单明细}.订单编号 = {销售订单主表}._Identify) INNER JOIN {库存明细表1} ON {销售订单明细}.库存入库编号 = {库存明细表1}._Identify) INNER JOIN {物料信息表} ON {库存明细表1}.MID = {物料信息表}._Identify) INNER JOIN {客户资料表} ON {销售订单主表}.CID = {客户资料表}._Identify

我现在想按客户购买产品生成一个统计表,有4列  客户名称,前年销售总量,去年销售总量,今天销售总量。试了好久都不能成功,能帮忙指点一下吗?



--  作者:有点色
--  发布时间:2017/6/5 14:16:00
--  

 如果是这样的话,建议先做一个视图,不然sql语句会变得太长。

 

 把你5楼的sql语句做成视图,命名为 销售订单信息表,然后写sql语句

 

Select 客户名称,(select Sum(产品数量) from {销售订单信息表} as b where 时间段 And 产品名称 = \'A\' and b.客户名称 = a.客户名称) As 前年销售数量 from {销售订单信息表} as a where 产品名称 = \'A\' Group by 客户名称