全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
SQL Server数据库多表关联汇总查询是我们经常用到的,本文我们就介绍了一个多表关联汇总查询的实例,通过这个实例在多表关联查询中遇到的问题以及它的解决方法让我们一起来了解一下SQL Server数据库多表关联汇总查询的相关知识吧SQL Server数据库多表关联汇总查询是我们经常用到的,本文我们就介绍了一个多表关联汇总查询的实例,通过这个实例在多表关联查询中遇到的问题以及它的解决方法让我们一起来了解一下SQL Server数据库多表关联汇总查询的相关知识吧,希望本次的介绍能够对您有所帮助。以下是代码片段:select isnull(s.mnumber,ss.mnumber) mnumber,isnull(m.whcode,ss.whcode) whcode, isnull(sum(factreceiptquan),0)-isnull(sum(factissuequan),0) + sum(isnull(ss.quan,0) quan from (select * from gy_inoutmain where billcode in(1201,1202,1203,1204,1205,1206) ) m inner join gy_inoutsub s on m.inoutmainid=s.inoutmainid left join( select sms.mnumber,sm.whcode,sum(sms.quan) quan from Kf_StartMain sm inner join Kf_Startsub sms on sm.startmainid=sms.startmainid group by sm.whcode,sms.mnumber ) ss on m.whcode=ss.whcode and s.mnumber=ss.mnumber group by isnull(m.whcode,ss.whcode),isnull(s.mnumber,ss.mnumber) order by s.mnumber 上面将收发表的数量进行汇总,然后再加上期初表的数量,得到库存量。但是得到的实际数量却多出很多来,比如本来物料“010101004”只有20吨,统计的结果却有5000多吨。问题出在哪里呢?以下是代码片段:select sms.mnumber,sm.whcode,sum(sms.quan) quan from Kf_StartMain sm inner join Kf_Startsub sms on sm.startmainid=sms.startmainid where sms.mnumber=010101004 group by sm.whcode,sms.mnumber 上面sql统计期初表 数量 = 31.500000以下是代码片段:select s.mnumber,m.whcode, isnull(sum(factreceiptquan),0)-isnull(sum(factissuequan),0) quan from (select * from gy_inoutmain where billcode in(1201,1202,1203,1204,1205,1206) ) m inner join gy_inoutsub s on m.inoutmainid=s.inoutmainid where s.mnumber=010101004 group by m.whcode,s.mnumber order by s.mnumber 上面sql统计收发表 数量 = -27.000000以下是代码片段:select s.mnumber,m.whcode, isnull(sum(factreceiptquan),0)-isnull(sum(factissuequan),0) +sum(ss.quan) quan from (select * from gy_inoutmain where billcode in(1201,1202,1203,1204,1205,1206) ) m inner join gy_inoutsub s on m.inoutmainid=s.inoutmainid left join( select sms.mnumber,sm.whcode,sum(sms.quan) quan from Kf_StartMain sm inner join Kf_Startsub sms on sm.startmainid=sms.startmainid where sms.mnumber=010101004 group by sm.whcode,sms.mnumber ) ss on m.whcode=ss.whcode and s.mnumber=ss.mnumber where s.mnumber=010101004 group by m.whcode,s.mnumber order by s.mnumber 上面sql关联两表,数量=57145.500000,原来,在收发表关联期初表,收发表有几百条记录,而期初表只有一条记录,两者一关联,则这几百条记录都有期初数,结果期初数被累加了几百次。举个例子:以下是代码片段:create table 期初表(MNUmber varchar(10),quan decimal(10,3) create table 收发表(MNUmber varchar(10),quan decimal(10,3) insert into 期初表 values(001,7) insert into 期初表 values(001,5) insert into 期初表 values(001,-9) insert into 收发表 values(001,10) select sum(quan) from 期初表 -期初表合计=3那得到的现存量应该是 收发表的合计 加上 期初数:3+10 = 13。但一关联,再汇总,就出问题了。以下是代码片段:select sum(m.Quan)+sum(s.Quan) from 收发表 m inner join 期初表 s on m.MNumber=s.MNumber group by m.MNumber 得到的结果是33。因为一关联,就变成:以下是代码片段:收发表.MNumber 收发表.quan 期初表.MNumbe
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 物业门窗装修合同范本
- 邮政集团入职合同范本
- Unit 9 Weather Report教学设计-2025-2026学年小学英语五年级上册新世纪版
- 物业物资采购合同范本
- 网点投放合作合同协议
- 礼服主持租赁合同范本
- 购物中心联营合同范本
- 银行电力中标合同范本
- 酒厂拆除回收合同范本
- 药品经销策划合同范本
- 2025北京市实验动物上岗证试题及答案
- 道路客运驾驶员从业资格年度考核报告
- 制药设备改造协议书
- 读书分享成品《窗边的小豆豆》课件
- 【2025年】员工食堂培训试题及答案
- 财务会计基本规范与操作手册
- DG-TJ08-401-2025 公共厕所规划和设计标准
- 见义勇为宣传课件
- 说话的艺术课件
- 个人信息保护规则及制度
- 货车安全培训案例分享课件
评论
0/150
提交评论