• 价值5000元的web报表分享


    价值5000元的web报表分享

    与一个朋友聊天,发现他最近做了一个很棒的报表,用他的话来讲,起码值5000RMB,我拿来与大家分享下,共同进步。

    用朋友A的话,就是他最近接到公司财务部长大人的需求,需要通过采购和研发部门的降本计划,统计出各部门的降本信息,然后如果让财务部的小妹手工统计的话,那简直是太困难了,如是求助IT人员用报表软件FineReport。

    朋友A通过仔细分析得出降本计划数据来源哪里,思索一番得出如下逻辑:

    ①核价单单头表包含信息:核价日期、供应商、主导部门

    ②核价单单身表包含信息:品号、核价单价、原单价、生效日期、失效日期

    ③采购进货单单头信息:单别、单据号、供应商、单据日期

    ④采购进货单单身信息:品号、名称、规格、进货单价、税率

    于是乎,朋友A想到办法难点是如何取到原单价,最终报表如下:

    原单价取价逻辑为当进货单单据日期在核价单生效日期和失效日期之间时抓取对应的核价单原单价信息。


    下面是获取原单价函数:

    ALTER Function [dbo].[UF_GetLastPrice](
    @TL004 AS nvarchar(10),
    @date as nvarchar(8),
    @item as nvarchar(30)
    )returns decimal(18,6)
    as
    begin
    --set @TL004='09001'
    --set @date='20150116'
    --set @item='10102069620001';
    declare @price as decimal(18,6);
    declare @zdbm as nvarchar(20);
    with b as(
    select TM004,TM014,TM018,TL004,PURTL.UDF01 from PURTL inner join PURTM ON TL001=TM001 AND TL002=TM002
    where TM011='Y' AND TL004=@TL004  and   TM014<=@date and TM004=@item)
    
    select @price=isnull(t.TM018,0),@zdbm=t.UDF01 from (
    select b.UDF01,b.TM004,b.TM018,ROW_NUMBER() over(partition by b.TM004 order by b.TM014 desc )rn
    from  b ) t
    where rn=1
    return  @price
    end
    

    如此,大功告成!




  • 相关阅读:
    C#操作ini配置文件和写入日志操作
    asp.net AJAX 定期刷新页面,然后,在 Timer 的事件中弹出窗口
    setInterval和setTimeout的区别
    检测远程URL是否存在
    SharePoint列表的模板类型中的BaseType参数和ListTemplate参数
    TCP中的Flag options
    jQuery基础教程摘录 Hello world
    SharePoint站点无法打开的问题
    SPQuery在引用field的时候要用internal name
    Windows Server 2008中用管理员的权限使用命令行来打开程序
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13326195.html
Copyright © 2020-2023  润新知