51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1740|回复: 3
打印 上一主题 下一主题

[求助] 求助sql问题,如何在存储过程中调用函数

[复制链接]
  • TA的每日心情

    1720761397
  • 签到天数: 1 天

    连续签到: 1 天

    跳转到指定楼层
    1#
    发表于 2017-6-21 13:42:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    函数如下:

    Alter function dbo.Pub_FN_FundsList
    (
    @d1 datetime,        --开始日期
    @d2 datetime,        --结束日期
    @sPrice numeric(18,2),        --每期金额
    @Term int,        --收付周期(月)
    @AheadDays int,        --提前收付天数
    @Align bit        --对齐方式:0对齐,1后对齐       

    )                          

    returns @TB table
    (
    [id] [int] IDENTITY(1,1) NOT NULL,
    AwokeDate datetime,  --提醒日期
    BeginDate datetime,  --开始日期
    EndDate datetime,  --结束日期
    sPrice numeric(18,2),--支付租金数字
    TrueDay int,--实际租住天数
    DayPrice numeric(4,2),--日租金
    MonthNumber int,--整月个数
    ExtraDays int,        --不满整月的天数
    MonthDays int      --本月天数       
    )

    as
    Begin
    declare @dtmp datetime
    --------------------------------------------------------------------------------------
    if(@Align=0)
    Begin
    set @dtmp=@d1;       
    while @dtmp<=@d2
    begin
              insert into @TB(BeginDate,EndDate,TrueDay,DayPrice,ExtraDays,MonthNumber,MonthDays)
    values(@dtmp
    ,dateadd(d,-1,DATEADD(m,@Term,@dtmp))
    --,DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)
    ,case when dateadd(d,-1,DATEADD(m,@Term,@dtmp))>@d2 then DATEDIFF(d,@dtmp,@d2+1)
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=59  then null
    when DATEDIFF(d,@d1,@dtmp+1)/30<>0 then null
    else DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)end
    ,(@sPrice/@Term)*12/365
    --,case when dateadd(d,-1,DATEADD(m,@Term,@dtmp))>@d2 then DATEDIFF(d,@dtmp,@d2+1)%31 else DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)%31 end
    ,case when dateadd(d,-1,DATEADD(m,@Term,@dtmp))>@d2 then DATEDIFF(d,@dtmp,@d2+1)%30
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=29 then 0
    when DATEDIFF(d,@d1,@dtmp+1)/30<>0 then null
    else 0  end
    ,case when dateadd(d,-1,DATEADD(m,@Term,@dtmp))>@d2 then DATEDIFF(d,@dtmp,@d2+1)/30
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=58 then 2
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1) =59 then 2
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=89 then 3
    when DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=28 or DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)=29 then 1
    else DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)/30 end
    ,DateDiff(d,DATEADD(MONTH,DATEDIFF(MONTH,0,@dtmp),0),DATEADD(MONTH,1+DATEDIFF(MONTH,0,@dtmp),0)))
        set @dtmp=dateadd(m,@Term,@dtmp)       
            end       
    End
    Else
    begin
    set @dtmp=@d2;
    while @dtmp>=@d1
    begin
              insert into @TB(BeginDate,EndDate,TrueDay,DayPrice,ExtraDays,MonthNumber,MonthDays)
    values(dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))
    ,@dtmp
    --,DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)
    ,case when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1 then DATEDIFF(d,@d1,@dtmp+1)
    when DATEDIFF(d,@d1,@dtmp+1)/30<>0 then null
    else DATEDIFF(dd,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)end
    ,case when DATEDIFF(d,@d1,@dtmp+1)/30<>0 then null else (@sPrice/@Term)*12/365 end
    ,case when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1 and DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=29 then 0
    --case when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1 then DATEDIFF(d,@d1,@dtmp+1)%30
    when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1 then DATEDIFF(d,@d1,@dtmp+1)%30
    when DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=29 then 0
    when DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=59 then 0
    when DATEDIFF(d,@d1,@dtmp+1)/30<>0 then null
    else 0 end
       ,case when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1  then DATEDIFF(d,@d1,@dtmp+1)/30
    when dateadd(d,1,DATEADD(m,-1*@Term,@dtmp))<@d1 or DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=59 then 2
    when DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=59 then 2
    when DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)=29 then 2
    else DATEDIFF(d,dateadd(d,1,DATEADD(m,-1*@Term,@dtmp)),@dtmp+1)/30 end
    ,DateDiff(d,DATEADD(MONTH,DATEDIFF(MONTH,0,@dtmp),0),DATEADD(MONTH,1+DATEDIFF(MONTH,0,@dtmp),0)))
    set @dtmp=dateadd(m,-1*@Term,@dtmp)
             
    end
    End
    --------------------------------------------------------------------------------------
    update @TB
    set AwokeDate=(case when dateadd(d,-1*@AheadDays,BeginDate)<@d1 then @d1 else dateadd(d,-1*@AheadDays,BeginDate) end)
    ,BeginDate=(case when BeginDate<@d1 then @d1 else BeginDate end)
    ,EndDate=(case when EndDate>@d2 then @d2 else EndDate end)
        --,TrueDay=(case when EndDate>@d2 then DATEDIFF(D,BeginDate,@d2+1) else DATEDIFF(d,@dtmp,dateadd(d,-1,dateadd(m,@Term,@dtmp))+1)end)
       -- MonthNumber=TrueDay/30
       ,sPrice=(case when MonthNumber = 0 and ExtraDays=15 then (@sPrice/@Term)/2
                when MonthNumber = 0 then TrueDay*DayPrice
                when MonthNumber<>0 and ExtraDays<>0 then DayPrice*TrueDay
                else(@sPrice/@Term)*MonthNumber end)
       --TrueDay=(case when sPrice = @sPrice then null end)
      -- ,MonthNumber=TrueDay/30
      -- ,ExtraDays=TrueDay%30

    --------------------------------------------------------------------------------------
    return;       
    End
    go
    select * from Pub_FN_FundsList('2017-5-22','2018-5-21',3000,3,5,0) order by AwokeDate
    select * from Pub_FN_FundsList('2017-1-15','2017-12-31',3000,1,5,1) order by AwokeDate



    我想在一个名为[dbo].[OA_LeaseContract_Finance_Proce_Init]这个的存储过程中直接调用这个函数,请问语法应该怎么写?

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    该用户从未签到

    2#
    发表于 2017-6-21 15:32:50 | 只看该作者
    存储过程:
    SQL code
    1. CREATE PROC dbo.OA_LeaseContract_Finance_Proce_Init
    2.     @date1 DATE ,
    3.     @date2 DATE
    4. AS
    5.     BEGIN
    6.         SELECT  *
    7.         FROM    Pub_FN_FundsList(@date1, @date2, 3000, 3, 5, 0)
    8.         ORDER BY AwokeDate;
    9.     END;
    10. GO
    复制代码

    调用:
    1. EXEC dbo.OA_LeaseContract_Finance_Proce_Init @date1 = '2017-06-13', -- date
    2.     @date2 = '2017-06-13'; -- date
    复制代码
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2024-7-12 13:16
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    3#
    发表于 2017-6-21 15:34:29 | 只看该作者
    1. if object_id('tempdb..#Tmp_Tbl') is not null
    2.                             drop table #Tmp_Tbl
    3.                              
    4.     CREATE TABLE #Tmp_Tbl (
    5.                 [id] [int]  NOT NULL,
    6.                 AwokeDate datetime,  --提醒日期
    7.                 BeginDate datetime,  --开始日期
    8.                 EndDate datetime,  --结束日期
    9.                 sPrice numeric(18,2),--支付租金数字
    10.                 TrueDay int,--实际租住天数
    11.                 DayPrice numeric(4,2),--日租金
    12.                 MonthNumber int,--整月个数
    13.                 ExtraDays int,    --不满整月的天数
    14.                 MonthDays int )     --本月天数   


    15. INSERT INTO  #Tmp_Tbl  Select * From dbo. dbo.Pub_FN_FundsList(@d1,@d2,@sPrice,@Term,@AheadDays,@Align)
    复制代码
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    前天 09:07
  • 签到天数: 11 天

    连续签到: 2 天

    [LV.3]测试连长

    4#
    发表于 2017-6-21 15:35:09 | 只看该作者
    直接在过程中:
    Select * From dbo. dbo.Pub_FN_FundsList('2017-06-17','2017-07-18',3000, 3, 5, 0)
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-9-21 05:35 , Processed in 0.065869 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表