sql server 2008中的存储过程执行与单独执行SQL语句结果不一致

涵妈妈 2018-10-16 09:37:46
存储过程:
ALTER PROCEDURE [dbo].[cb_4s_ds]


@startdate1 datetime,@enddate1 datetime

AS
BEGIN

SET NOCOUNT ON;

select a.resourcecode,a.resourcename,count(distinct a.frameno) liangshu,sum(a.sumpremium) bnbaofei into #bncbhuizong
from NewData a
where a.operatedate between @startdate1 and @enddate1
group by a.resourcecode,a.resourcename

select b.resourcecode,count(distinct b.frameno) dsliangshu,sum(b.sumverilossfee) bndsjiner into #bndshuizong
from dsdata b
where b.enddeflossdate between @startdate1 and @enddate1
group by b.resourcecode

select a.resourcecode,a.resourcename,liangshu,cast(bnbaofei/10000 as decimal(38,2)) baofei1,b.dsliangshu,cast(bndsjiner/10000 as decimal(38,2))dsjiner,
cast(cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) as varchar)+'%' AS rate
from #bncbhuizong a left join #bndshuizong b
on a.resourcecode=b.resourcecode
order by cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) desc

END

exec cb_4s_ds'2018-10-12','2018-10-14'




单独执行SQL:
select a.resourcecode,a.resourcename,count(distinct a.frameno) liangshu,sum(a.sumpremium) bnbaofei into #bncbhuizong
from NewData a
where a.operatedate between '2018-10-12' and '2018-10-12'
group by a.resourcecode,a.resourcename

select b.resourcecode,count(distinct b.frameno) dsliangshu,sum(b.sumverilossfee) bndsjiner into #bndshuizong
from dsdata b
where b.enddeflossdate between '2018-10-12 00:00:00' and '2018-10-14 00:00:00'
group by b.resourcecode

select a.resourcecode,a.resourcename,liangshu,cast(bnbaofei/10000 as decimal(38,2)) baofei1,b.dsliangshu,cast(bndsjiner/10000 as decimal(38,2))dsjiner,
cast(cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) as varchar)+'%' AS rate
from #bncbhuizong a left join #bndshuizong b
on a.resourcecode=b.resourcecode
order by cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) desc


以上存储过程执行和单独SQL执行中的部分结果是不一致的,请给予帮助解决,谢谢!
...全文
903 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
king4323210 2018-10-19
  • 打赏
  • 举报
回复
个人建议,你不能着迷于展示结果,如果你能去比对两种方法查询的数据源,结果不一样,可以肯定的是数据源也会不一样,你把两个结果的数据源再进行一次LEFT JOIN,WHERE 存储过程的数据源的一个字段 IS NULL 这样就能看出是多了哪部分数据,再仔细比对一下你的查询条件,看是不是时间的问题,,,因为between and是包含的意思,也许正巧会有2018-10-10 00:00:00.000 这样的数据 希望对你有帮助
涵妈妈 2018-10-16
  • 打赏
  • 举报
回复
where a.operatedate between @startdate1 and @enddate1


where b.enddeflossdate between @startdate1 and @enddate1


where a.operatedate between '2018-10-12' and '2018-10-14'


where b.enddeflossdate between '2018-10-12 00:00:00' and '2018-10-14 00:00:00'

--------------------------------------------------------------------------------------------------------------------------
您好!这个时间改成了
where a.operatedate between '2018-10-12' and '2018-10-14'


where b.enddeflossdate between '2018-10-12 ' and '2018-10-14 '

执行结果还是不一致
卖水果的net 2018-10-16
  • 打赏
  • 举报
回复
where a.operatedate between @startdate1 and @enddate1 where b.enddeflossdate between @startdate1 and @enddate1 where a.operatedate between '2018-10-12' and '2018-10-14' where b.enddeflossdate between '2018-10-12 00:00:00' and '2018-10-14 00:00:00'
涵妈妈 2018-10-16
  • 打赏
  • 举报
回复
sql语句的enddate和参数的不一样
where a.operatedate between @startdate1 and @enddate1

where a.operatedate between '2018-10-12' and '2018-10-12'
------------------------------------------------------------------------------------
黏贴粘错了,应该是:a.operatedate between '2018-10-12' and '2018-10-14'
单独执行SQL:
select a.resourcecode,a.resourcename,count(distinct a.frameno) liangshu,sum(a.sumpremium) bnbaofei into #bncbhuizong
from NewData a
where a.operatedate between '2018-10-12' and '2018-10-14'
group by a.resourcecode,a.resourcename

select b.resourcecode,count(distinct b.frameno) dsliangshu,sum(b.sumverilossfee) bndsjiner into #bndshuizong
from dsdata b
where b.enddeflossdate between '2018-10-12 00:00:00' and '2018-10-14 00:00:00'
group by b.resourcecode

select a.resourcecode,a.resourcename,liangshu,cast(bnbaofei/10000 as decimal(38,2)) baofei1,b.dsliangshu,cast(bndsjiner/10000 as decimal(38,2))dsjiner,
cast(cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) as varchar)+'%' AS rate
from #bncbhuizong a left join #bndshuizong b
on a.resourcecode=b.resourcecode
order by cast(b.bndsjiner*100/a.bnbaofei as decimal(38,2)) desc

还有一个问题:
如果我执行存储过程:exec cb_4s_ds'2018-10-12','2018-10-12'
单天的话存储过程和SQL的结果是一致的,只要执行分时间区间就会不一致了。
二月十六 2018-10-16
  • 打赏
  • 举报
回复
sql语句的enddate和参数的不一样
where a.operatedate between @startdate1 and @enddate1

where a.operatedate between '2018-10-12' and '2018-10-12'
涵妈妈 2018-10-16
  • 打赏
  • 举报
回复
单独执行SQL结果:
resourcecode resourcename liangshu baofei1 dsliangshu dsjiner rate
1310001000382 廊坊华驰汽车销售服务有限公司 1 0.52 9 5.58 1066.05%
1310002000037 河北怡和骏祥汽车销售服务有限公司(上海通用) 3 0.54 6 2.67 495.87%
1310077000139 廊坊汇之杰汽车销售有限公司 1 0.25 1 1.00 407.08%
1310083000377 河北禾腾汽车销售服务有限公司 1 0.57 1 2.03 354.08%
1310018000305 廊坊市福江汽车销售服务有限公司 2 0.64 3 1.93 299.55%
1310027000046 廊坊市君泰悦轩汽车销售有限公司(东风本田 ) 4 2.18 5 4.31 197.74%
1310057000309 廊坊市瑞川汽车销售有限公司 16 5.82 7 7.80 134.11%
1310049000136 廊坊瑞亨伟业汽车销售有限公司 11 5.14 10 5.43 105.63%
1310015000036 廊坊市瑞龙伟业汽车销售服务有限公司(北京现代) 45 14.30 17 11.16 78.03%
1310001000031 廊坊市东方华明汽车修理有限公司(上海大众) 33 19.57 16 13.14 67.15%
1310001716066 廊坊市盛德基业汽车销售服务有限公司(上海大众) 25 9.56 14 4.49 46.94%
1310018000106 廊坊市瑞泰汽车销售有限公司(福特) 11 4.14 4 1.85 44.54%
1310015000105 廊坊万运汽车销售有限公司(北京现代) 13 3.96 3 1.76 44.53%
1310053000383 廊坊华爵汽车销售服务有限公司 4 3.19 4 1.16 36.46%
1310014000365 廊坊瑞岑汽车销售有限公司 3 1.44 2 0.52 36.38%
1310024000212 廊坊博鼎汽车销售有限公司 2 1.05 2 0.38 35.89%
1310045000039 廊坊乾开汽车销售有限公司 38 12.86 6 3.11 24.21%
1310053000157 廊坊市燕达汽车贸易有限公司 7 2.69 3 0.54 20.21%
1310054000120 廊坊廊大汽车服务有限公司(荣威、名爵) 15 5.11 2 0.82 16.00%
1310074000137 廊坊华盛昌辰悦汽车贸易有限公司 3 1.74 1 0.15 8.62%
1310024000045 廊坊市悦众信达汽车销售有限公司(起亚) 13 3.84 1 0.28 7.29%
1310047000303 廊坊瑞吉伟业汽车销售有限公司 20 5.97 1 0.36 6.04%
1310023000356 华盛昌汽车(廊坊)有限公司 9 4.39 NULL NULL NULL

执行存储过程结果:
resourcecode resourcename liangshu baofei1 dsliangshu dsjiner rate
1310001000382 廊坊华驰汽车销售服务有限公司 1 0.52 9 92.81 17738.13%
1310077000139 廊坊汇之杰汽车销售有限公司 1 0.25 1 27.96 11398.34%
1310083000377 河北禾腾汽车销售服务有限公司 1 0.57 1 34.57 6019.28%
1310027000046 廊坊市君泰悦轩汽车销售有限公司(东风本田 ) 4 2.18 5 73.19 3355.32%
1310002000037 河北怡和骏祥汽车销售服务有限公司(上海通用) 3 0.54 6 12.39 2305.43%
1310049000136 廊坊瑞亨伟业汽车销售有限公司 11 5.14 10 79.23 1539.98%
1310015000036 廊坊市瑞龙伟业汽车销售服务有限公司(北京现代) 45 14.30 17 217.97 1523.93%
1310001000031 廊坊市东方华明汽车修理有限公司(上海大众) 33 19.57 16 258.01 1318.41%
1310014000365 廊坊瑞岑汽车销售有限公司 3 1.44 2 10.91 757.31%
1310024000212 廊坊博鼎汽车销售有限公司 2 1.05 2 7.81 745.47%
1310057000309 廊坊市瑞川汽车销售有限公司 16 5.82 7 41.49 713.33%
1310001716066 廊坊市盛德基业汽车销售服务有限公司(上海大众) 25 9.56 14 68.11 712.62%
1310053000383 廊坊华爵汽车销售服务有限公司 4 3.19 4 20.96 656.20%
1310015000105 廊坊万运汽车销售有限公司(北京现代) 13 3.96 3 24.82 626.26%
1310018000106 廊坊市瑞泰汽车销售有限公司(福特) 11 4.14 4 21.37 515.63%
1310045000039 廊坊乾开汽车销售有限公司 38 12.86 6 49.47 384.75%
1310024000045 廊坊市悦众信达汽车销售有限公司(起亚) 13 3.84 1 13.72 357.04%
1310054000120 廊坊廊大汽车服务有限公司(荣威、名爵) 15 5.11 2 15.75 308.20%
1310018000305 廊坊市福江汽车销售服务有限公司 2 0.64 3 1.93 299.55%
1310053000157 廊坊市燕达汽车贸易有限公司 7 2.69 3 5.39 200.57%
1310074000137 廊坊华盛昌辰悦汽车贸易有限公司 3 1.74 1 0.15 8.62%
1310047000303 廊坊瑞吉伟业汽车销售有限公司 20 5.97 1 0.36 6.04%
1310023000356 华盛昌汽车(廊坊)有限公司 9 4.39 NULL NULL NULL


主要就是dsjiner这个字段的值有差。
SQL Server 2005微软官方权威参考手册     是Inside Microsoft SQL Server 2005系列书的第一本,SQL Server类的顶尖之作   全球公认SQL Server 2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。       本系列图书文版得到了微软总部SQL Server组专家的高度重视,同时也得到了微软国上海SQL Server全球技术支持心的高度关注。        本书详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的问题。本书涵盖了T-SQL程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-SQL和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户、使用Service Broker来控制数据库应用程序的异步处理等。   内容简介 本书是Inside Microsoft SQL Server 2005系列四本著作的一本。它详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。它提供了使用Transact-SQL(T-SQL)的专家级指导,T-SQL是用于SQL Server的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被SQL Server引擎解释和处理。   通过本书,你将深入了解T-SQL的高级用法,包括触发器、用户自定义函数、异常处理等。该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-SQL。   本书适合于专业数据库开发者、BI开发者、DBA和以SQL Server作为后台数据库的一般应用程序开发者,读者可以通过书的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际问题。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft SQL Server MVP(最有价值专家),并在全世界已经开展过无数次T-SQL查询、T-SQL优化和编程方面的培训。Itzik是Microsoft SQL Server方面几本著作的作者。他在SQL ServerMagazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种SQL用户组、PASS、SQL server Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要求、修复问题、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-SQL查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列SQL Server和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的问题,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理   Datetime相关的查询问题  1.2 与字符相关的问题   模式匹配   区分大小写(Case-Sensitive)的筛选器  1.3 大型对象(Large Object,LOB)   MAX 说明符   BULK行集提供程序  1.4 隐式转换(Implicit Conversion)   标量表达式   筛选表达式  1.5 基于CLR的用户定义类型   UDT理论简介   开发UDT  1.6 XML数据类型   关系数据库的XML支持   什么时候应该使用XML代替关系表现形式?   数据库的XML序列化对象   使用开放架构(Open Schema)的XML   作为存储过程参数的XML数据类型   Xquery修改语句  1.7 结论 第2章 临时表和表变量  2.1 临时表   局部临时表   全局临时表  2.2 表变量   限制条件   tempdb   范围和可见性   事务上下文   统计信息  2.3 tempdb相关的注意事项  2.4 表表达式  2.5 比较临时对象  2.6 综合练习——关系分区(Relational Division)  2.7 结论 第3章 游标  3.1 使用游标  3.2 游标开销  3.3 单独处理每一行  3.4 按顺序访问   自定义聚合   连续聚合   最大并发会话   匹配问题  3.5 结论 第4章 动态SQL 第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章 触发器 第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库: SQL Server A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和 SQL Server 索引 英文术语对照表

22,206

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧