zoukankan      html  css  js  c++  java
  • 五、K3 WISE 开发插件《直接SQL报表开发新手指导

    ========================

    目录:

    1、直接SQL报表

    ========================

    1、直接SQL报表

    以BOM成本报表为例,在销售模块部署,需要购买【金蝶 K3 BOS集成开发工具】使用许可

    I、本报表采用存储过程的形式编写,需要在数据库执行存储过程。

    /****** Object:  StoredProcedure [dbo].[pro_bobang_BOMCost]    Script Date: 07/29/2015 16:09:11 ******/
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    create PROC [dbo].[pro_bobang_BOMCost]
    @FBomNumber1 varchar(50),  --bom单号
    @FBomNumber2 varchar(50)   --bom单号
    as
    begin
    SET ANSI_WARNINGS OFF
    set nocount on
    
    
    --1.--业务员查找某个BOM单,包含所有BOM(已使用,未使用,已审核,未审核)
      ;with cte as (
      select convert(varchar(100),'') as cen,Finterid,FBOMNumber as fppbomnumber,convert(varchar(50),'') as fpbomnumber,Fbomnumber AS FCbomnumber,fitemid,fitemid as fpitemid,0 as fpinterid,convert(decimal(18,4),1) as FBomQty,convert(varchar(500),RIGHT('000000'+CONVERT(varchar(10),Finterid),6)) as code  from ICBOM 
      where (1=1)
      and FBOMNumber >= @FBomNumber1
      and FBOMNumber <= case when @FBomNumber2='' then (select MAX(FBOMNumber) from ICBOM) else @FBomNumber2 end
      union all
      select convert(varchar(100),cen+'------'),a.finterid,c.fppbomnumber,convert(varchar(50),c.FCbomnumber) as fpbomnumber,a.fbomnumber as fcbomnumber,a.fitemid,c.fpitemid,a.fpinterid,convert(decimal(18,4),a.FAuxQty) as FBomQty,convert(varchar(500),c.code+RIGHT('000000'+convert(varchar(10),a.finterid),6)) as code
      from ( 
      select t1.finterid as fpinterid,t2.FInterID,t1.FItemID,t2.FBOMNumber,t1.FAuxQty 
      from  ICBOMChild t1 inner join ICBOM t2 on t1.FItemID=t2.FItemID
      where FParentID=1038
      union all 
      select t1.finterid as fpinterid,0,t1.fitemid,'',t1.FAuxQty from ICBOMChild t1 where not exists (select * from ICBOM where FItemID=t1.FItemID)) a 
      inner join cte c on a.fpinterid=c.FInterID
      )
      select  cen,finterid,fppbomnumber,fpbomnumber,fcbomnumber,fitemid,fpitemid,fpinterid,FBomQty,code into #tmp1 from cte order by code
      OPTION (MAXRECURSION 0)
    
    --2.--取采购价格管理物料最新日期的价格(已审核,可使用)
    SELECT distinct u1.FSupID,u1.FItemID,case when u1.fcyid=1 then u1.FPrice*t3.FExchangeRate/(1+v1.FValueAddRate/100) else u1.FPrice*t3.FExchangeRate end as FPrice,
    t3.FName AS FCyName,u1.FQuoteTime,u1.FDisableDate
    into #tmp2 FROM t_SupplyEntry  u1 
         INNER JOIN t_ICItem t1 ON u1.FItemID=t1.FItemID
         INNER JOIN t_Supply u2 ON u1.FSupID=u2.FSupID AND u1.FItemID=u2.FItemID AND u1.FPType=u2.FPType
         INNER JOIN t_Currency t3 ON t3.FCurrencyID=u1.FCyID
         INNER JOIN t_Currency u3 ON u3.FCurrencyID=u2.FCurrencyID
         INNER JOIN t_Supplier v1 ON u1.FSupID=v1.FItemID
         inner join 
         (
         select MAX(fquotetime) as fquotetime,FItemID from t_SupplyEntry where FCheckerID>0 group by FItemID
         ) bb on bb.FItemID=u1.FItemID and bb.fquotetime=u1.FQuoteTime
     WHERE t1.FErpClsID not in (6,8) and u1.FCheckerID>0 and u1.FUsed=1
    
    --3.--列出BOM明细成本,取采购价格的最新价格
    select t1.cen+t1.code as FTree,t1.cen,t1.code,t1.fppbomnumber,t1.fpbomnumber,t1.fcbomnumber,t1.FItemID,t1.FBomQty,
    t2.FSupID,t2.FPrice as FAuxPrice,t1.FBomQty*t2.FPrice as FAmount,case when FCbomnumber<>'' then t1.FBomQty*t2.FPrice end as FJGAmount 
    into #tmp3 from #tmp1 t1
    left join #tmp2 t2 on t1.FItemID=t2.FItemID
    left join t_ICItem t3 on t1.FItemID=t3.FItemID
    order by t1.code,t3.FNumber
    
    
    --4.--循环计算中间件成本
    ---这部分部署会出错,先注释,部署成功,再解除注释更新存储过程
    declare @cb decimal(18,4),@fbom varchar(50),@fppbom varchar(50)
    declare auth_cur cursor for
    select fppbomnumber,fcbomnumber from #tmp3 where FAuxPrice is null and fcbomnumber<>'' and cen<>''  order by cen desc
    open auth_cur
    fetch next from auth_cur into @fppbom,@fbom
    while(@@fetch_status=0)
    begin
      set @cb=0
      select @cb=isnull(SUM(FAmount),0) from #tmp3 where fpbomnumber=@fbom and fppbomnumber=@fppbom
      UPDATE #tmp3 set FAmount=isnull(FAmount,0)+@cb,FAuxPrice=isnull(FAuxPrice,0)+@cb/FBomQty where FCbomnumber=@fbom and fppbomnumber=@fppbom
      fetch next from auth_cur into @fppbom,@fbom
    end
    close auth_cur
    deallocate auth_cur
    ----这部分部署会出错,先注释,部署成功,再解除注释更新存储过程
    
    
    --5.--循环计算成品件成本
    ---这部分部署会出错,先注释,部署成功,再解除注释更新存储过程
    declare @cb1 decimal(18,4),@fbom1 varchar(50),@fppbom1 varchar(50)
    declare auth_cur cursor for
    select fppbomnumber,fcbomnumber from #tmp3 where fcbomnumber<>'' and cen=''  order by cen desc
    open auth_cur
    fetch next from auth_cur into @fppbom1,@fbom1
    while(@@fetch_status=0)
    begin
      set @cb1=0
      select @cb1=isnull(SUM(FAmount),0) from #tmp3 where fpbomnumber=@fbom1 and fppbomnumber=@fppbom1
      UPDATE #tmp3 set FAmount=isnull(FAmount,0)+@cb1,FAuxPrice=isnull(FAmount,0)+@cb1/FBomQty where FCbomnumber=@fbom1 and fppbomnumber=@fppbom1
      fetch next from auth_cur into @fppbom1,@fbom1
    end
    close auth_cur
    deallocate auth_cur
    ----这部分部署会出错,先注释,部署成功,再解除注释更新存储过程
    
    select t1.FTree,case when t1.fpbomnumber='' then t1.FCbomnumber end as fpbomnumber,t2.FNumber,t2.FName,t2.FModel,t3.FName as FUnitName,t1.FBomQty,t1.FAuxPrice,t1.FAmount,t1.FJGAmount,t4.FName as FSupName from #tmp3 t1
    inner join t_ICItem t2 on t2.FItemID=t1.FItemID
    inner join t_MeasureUnit t3 on t2.FUnitID=t3.FItemID
    left join t_Supplier t4 on t1.FSupID=t4.FItemID
    order by t1.code
    
    
    drop table #tmp1
    drop table #tmp2
    drop table #tmp3
    set nocount off
    
    end 
    
    --exec pro_bobang_BOMCost 'BOM000001','BOM000001'
    --exec pro_bobang_BOMCost '*FBomNumber*','#FBomNumber#'
    

     II、打开【金蝶K3 BOS集成开发工具】- - 【销售管理】- - 【直接SQL报表】,新建直接SQL报表。

    III、打开报表向导。

    IV、点击关键字维护,添加过滤条件关键字*FBomNumber*、#FBomNumber#。,并输入生成报表的SQL语句

    V、报表标题默认显示,和字段名称一样,是英文名称,修改报表标题为中文名称显示。

    技巧性:在存储过程最后显示结果集,可以直接给字段加上中文别名,这样此处就不需要再去修改报表标题。

  • 相关阅读:
    org.apache.commons.io.FilenameUtils 常用的方法
    (转)同一服务器部署多个tomcat时的端口号修改详情
    JavaWeb中监听器+过滤器+拦截器区别、配置和实际应用
    idea tomcat服务器运行打印日志到控制台是乱码解决方案
    spring boot 添加整合ssl使得http变成https方法
    Fiddler 抓包工具总结
    一些概念
    观点汇总
    Spring 问题总结
    tomcat和jetty区别
  • 原文地址:https://www.cnblogs.com/zhugq02/p/11236652.html
Copyright © 2011-2022 走看看