


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025重庆庆铃车桥有限公司招聘4人备考考试题库附答案解析
- 2025安徽芜湖无为市聘用专职人民调解员2人考试参考试题及答案解析
- 2026年中国银行校园招聘备考练习试题及答案解析
- 游戏业界:新纪元展望
- 手指谣小熊猫教学课件
- 社会网络分析-第3篇-洞察及研究
- 不生孩子合同8篇
- 人教版四年级数学上学期第4单元三位数乘两位数综合素养评价卷(含答案)
- 幼儿园班级游戏开展方案
- 学生防震减灾安全培训课件
- 跨学科实践活动07 垃圾的分类与回收利用(活动设计)-2024-2025学年九年级化学跨学科实践活动教学说课稿+设计(人教版2024)
- 2025年亚马逊AWS云服务合同范本参考
- 班干部聘任仪式
- 2025年老年病学住院医师规培出科考试理论笔试答案及解析
- 激光武器物理课件
- 气瓶泄漏应急演练范文大全
- 2025年REACH 250项高度关注物质SVHC清单第34批
- 2025年软件架构师专业技术考核试题及答案解析
- 八上语文第9课《天上有颗南仁东星》课件
- 2025-2026学年苏教版(2024)小学科学三年级上册(全册)课时练习及答案(附目录P102)
- DBJT15-110-2015 广东省建筑防火及消防设施检测技术规程
评论
0/150
提交评论