佩特来项目经验小集合(3)___从多表统计金额汇总到一张表

来这个项目主要是佩特来公司各部门及各代理商使用的系统,这个系统其中的一下功能就是统计代理商费用。费用的统计放在了费用池(传统方式统计代理商费用就叫费用池)数据表中,代理商可以根据费用池的中的金额购买东西,费用池中的钱来自于代理商每次填写的维修鉴定单中。

下面看一下这部分的数据表结构:

下面的存储过程是汇总材料费及其他费用表的费用并汇总到费用池信息表的存储过程,这段代码有点长,加入了各种判断:

-- =============================================
-- Author:		马兆娟
-- Create date: 2014-7-20 15:32:16
-- Description:	统计材费及其他费用汇总到费用池
-- =============================================
CREATE PROCEDURE [dbo].[PROC_WXJD_CommitFee]
	-- Add the parameters for the stored procedure here
	@wxjdId int,   --维修鉴定单ID
	@dlsId int     --代理商ID
AS
DECLARE
	@Err1 int,  --声明变量,事务使用
	@Err2 int,   --声明变量,事务使用
	@glf decimal, --管理费
	@gsf decimal, --工时费
	@xj decimal,   --小计
	@totalMoney decimal, --总金额
	@count int,  --整型数据
	@LJGLF decimal, --零件管理费
	@LJGSF decimal, --零件工时费
	@QTFY decimal,  --其他费用
	@WXJDTotalMoney decimal  --总金额

BEGIN
	BEGIN TRANSACTION   --开启事务

	SELECT @count=0; --给变量赋值

    --下面统计其他费用
	SELECT @count=count(*) FROM T_DLS_WXJD_Cost_QTFY WHERE [email protected]
	IF @count>0   --判断其他费用表是否已写入其他费用值,下面给小计赋值
	BEGIN
	   SELECT @xj = CASE SUM(xj) WHEN null THEN 0 ELSE Sum(xj) END  FROM T_DLS_WXJD_Cost_QTFY WHERE [email protected];
	END
	ELSE
	BEGIN
	  SELECT @xj=0;
	END
	--下面是统计材料费
	SELECT @count=0;
	SELECT @count=count(*) FROM T_DLS_WXJD_Cost_CLF WHERE Fid [email protected]
	IF @count>0  --判断材料费表是否已写入材料费,下面给管理费、工时费赋值
	BEGIN
	   SELECT @glf = CASE SUM(GLF) WHEN null then 0 ELSE SUM(GLF) END ,@gsf = CASE SUM(gsf) WHEN null THEN 0 ELSE Sum(gsf) END
		  FROM T_DLS_WXJD_Cost_CLF WHERE Fid [email protected]
	END
	ELSE
	BEGIN
	 SELECT @glf=0;
	 SELECT @gsf=0;
	END
	--下面给总金额赋值
	SELECT @totalMoney = @xj + @glf + @gsf;
	  --print @totalMoney;
	--下面将从其他费用及材料费中统计的金额写入费用池
	SELECT @count =0;
	SELECT @count=COUNT(*) FROM T_FeeExist WHERE DLSID = @dlsId;
	IF @count>0 --判断费用池表是否已写入某代理商费用,如果已写入过代理商费用,则需向代理商各项费用上添加统计的费用
	BEGIN
	   SELECT @LJGLF=LJGLF,@LJGSF=LJGSF,@QTFY=QTFY,@WXJDTotalMoney=WXJDTotalMoney FROM T_FeeExist WHERE DLSID = @dlsId;
	   SELECT @[email protected][email protected];
	   SELECT @[email protected][email protected];
	   SELECT @[email protected][email protected];
	   SELECT @[email protected][email protected];
	   UPDATE T_FeeExist SET [email protected],[email protected],[email protected],[email protected] WHERE DLSID = @dlsId;

	END
	ELSE     --第一次向费用池写入某代理商费用,添加新记录
	BEGIN
	INSERT INTO	T_FeeExist(DLSID,LJGLF,LJGSF,QTFY,WXJDTotalMoney) values(@dlsId,@glf,@gsf,@xj,@totalMoney);
	END
	SET @[email protected]@ERROR 

	--更新维修鉴定表是否已提交到费用池字段
	UPDATE T_DLS_WXJD SET IsFYC='是' WHERE [email protected]
	SET @[email protected]@ERROR 

  	   --判断是否出错
		IF (@Err1=0 and @Err2=0 )
			COMMIT TRANSACTION   --提交事务
		ELSE
			ROLLBACK TRANSACTION  --事务回滚
END

统计费用就简单的介绍到这里了,这里主要记录的关键点就是如何汇总各表的数据及存储过程中对数值进行判断!

佩特来项目经验小集合(3)___从多表统计金额汇总到一张表

时间: 2024-08-27 13:05:48

佩特来项目经验小集合(3)___从多表统计金额汇总到一张表的相关文章

佩特来项目经验小集合(2)___组合查询存储过程,报错 "varchar JBID='' 转换成数据类型 int 时失败"

今天写一个组合查询的存储过程遇到这样一个问题:在将 varchar 值 'SELECT * FROM View_DLS_WXJD_Customer WHERE 1=1 and JBID ='' 转换成数据类型 int 时失败.错误详情如图所看到的: 经百度:字符串变量和整型变量连接不能用+连接. 于是我採用cast()函数将DLSJB这个整型变量转换成字符串,这样问题就攻克了. 正确代码例如以下所看到的: ALTER PROCEDURE [dbo].[Proc_SH_WXJDList] @DH

佩特来项目经验小集合(2)___组合查询存储过程,报错 "varchar JBID='' 转换成数据类型 int 时失败"

今天写一个组合查询的存储过程遇到这样一个问题:在将 varchar 值 'SELECT * FROM View_DLS_WXJD_Customer WHERE 1=1 and JBID ='' 转换成数据类型 int 时失败.错误详情如图所示: 经百度:字符串变量和整型变量连接不能用+连接.于是我采用cast()函数将DLSJB这个整型变量转换成字符串,这样问题就解决了.正确代码如下所示: ALTER PROCEDURE [dbo].[Proc_SH_WXJDList] @DH varchar(

佩特来项目经验小集合(5)___系统流程设计

在佩特来项目设计中有一个流程设计问题,虽然.NET 和Java都有工作流,但是考虑到这个项目小,这里就简单的借用一点工作流的思想,设计了几张表,然后通过代码来控制流程.下面以"维修鉴定单业务流程"中的有实物流程为例,谈一下具体的流程设计.有实物的维修鉴定业务流程包含大致步骤:代理商填单.打印二维码.拆包.沟通转办.拆分.故障分析.各角色对费用进行审批.费用提交到费用池(统计各代理商金钱的地方).维修鉴定单流程见下图: 因为系统中不止这一个业务流程,所以系统流程设计的表有任务表(如维修鉴

佩特来项目经验小集合(1)___js获取前一页面url中传来的值

页面跳转代码: src="AddCLFFour.aspx?ID=<%= Request.QueryString["ID"].ToString() %>"> ,通过" Request.QueryString["ID"].ToString()" 向AddCLFFour传参数ID,在AddCLFFour页面如何获取页面传过来的ID值呢? 下面提供三种方法,简单介绍如何实现js获取前一页面传来的值 1.最简单的方法 

佩特来项目经验小集合(4)___SQL SERVER的逆向工程,将数据库导入到PowerDesigner中

PD是一款不错的数据库设计工具,在佩特来这个项目中,起初,合作伙伴用PD大体设计了10张表,我们在项目开发的时候直接采用正向工程,将PD设计的数据库直接导入SQLServer中即可创建数据库及表结构,随着项目的开发,我们对表结构及表数量等进行了更改,为了保证数据库与PD图的一致性,这里我们采用逆向工程,将数据库导入到PD中,Oracle.SqlServer等数据库,都是可以采用逆向工程将数据库导入到PD中的.SqlServer逆向工程,首先需要建立一个数据库的连接,然后再进行逆向工程操作.下面简

佩特来项目经验小集合(6)___ASP.NET模板页的读取

在佩特来售后管理系统流程中,其中有一个节点是故障分析,也就是将发回来的整机进行故障分析,传统的方法是将每个整机的故障信息录入一个Excel表,表格Excel样式: 这里是将Excel转换成模板页,然后根据需要替换模板中的标签,将功能完整展示,下面介绍在这个功能在项目中实现步骤: 1.将Excel转换为网页 打开Excel文档,单击菜单栏中的"文件",找到"另存为",如图所示.在"另存为" 窗口的"保存类型",下拉菜单中找到&q

小项目创意大集合

每个程序员都可以入手的小项目创意大集合 我经常看有人发帖问关于软件项目创意点子的事,也看到了很多回帖,我自己也回了一些常见的软件项目创意.不过我觉得只列出三两个是远远不够的,因此就收集并这个软件项目创意列表,大家要找简单的编程软件项目创意学习练手的话,可以收藏并扩散本文.这些软件项目创意并不是论文级别的,只是想抛砖引玉让大家能从中受些启发. 下面你们会看到 120 多个个软件项目创意想法,都是我通过头脑风暴得来的.我将其根据主题分成了10 个分类,但有些软件项目创意其实涵盖了不止一个主题. 更新

暑期报修项目经验分享二(附原码)

楔子 第二期项目经验分享,其实整个项目流程,我们只是参与了其中一小部分,仅仅是添加了材料管理模块的内容,在第一期的实践里面,主要维护材料类别的增查改操作.二期维护做的是材料出入库处理,因为我处理的是入库管理这一块,所以分享下做这一块的经验. 需求分析: 在分析业务需求的时候,因为考虑到出入库在一张数据表里面,即是共用数据,那么type区分出入库,在写代码的时候一个反人类的操作就是把流水号设置成整形,虽然影响不大,另外关于材料类别代码这里,因为材料类别是三级联动设置,所以我们只取最后一级的代码,因

如何在面试中介绍自己的项目经验

在面试时,经过寒暄后,一般面试官会让介绍项目经验 .常见的问法是,说下你最近的(或最拿得出手的)一个项目. 根据我们的面试经验,发现有不少候选人对此没准备,说起来磕磕巴巴,甚至有人说出项目经验从时间段或技术等方面和简历上的不匹配,这样就会造成如下的后果. 第一印象就不好了,至少会感觉该候选人表述能力不强. 一般来说,面试官会根据候选人介绍的项目背景来提问题,假设面试时会问10个问题,那么至少有5个问题会根据候选人所介绍的项目背景来问,候选人如果没说好,那么就没法很好地引导后继问题了,就相当于把提