ALTER procedure [dbo].[performance]
@startdate nvarchar(100),
@enddate nvarchar(100)
as begin
set NOCOUNT on;
select l.LocName,
v.Vtype,
SUM(DATEDIFF(MI,t.Paydate,t.DelDate)) as TotalDiff,
[dbo].[testfunction](CONVERT(decimal(10,1), AVG(
CONVERT(NUMERIC(18,2), DATEDIFF(SS,t.Paydate,t.DelDate) ) ))) as Average
from
Transaction_tbl t
left join
VType_tbl v
on t.vtid=v.vtid
left join
Location_tbl l
on t.Locid=l.Locid
where
t.Locid in(select t1.Locid from Transaction_tbl t1) and
dtime between '' + @startdate +'' and ''+@enddate+'' and
Status =5
group by v.Vtype,l.LocName,l.Locid order by l.Locid
end
我也有一个这样的功能:
ALTER FUNCTION [dbo].[testfunction] (@dec NUMERIC(18, 2)) RETURNS Varchar(50)
AS
BEGIN
DECLARE
@hour integer,
@Mns integer,
@second decimal(18,3)
DECLARE @Average Varchar(50)
select @hour=CONVERT(int,@dec/60/60)
SELECT @Mns = convert(int, (@dec / 60) - (@hour * 60 ));
select @second=@dec % 60;
SELECT @Average =
convert(varchar(9), convert(int, @hour)) + ':' +
right('00' + convert(varchar(2), convert(int, @Mns)), 2) + ':' +
right('00' + CONVERT(decimal(10,0), convert(varchar(6), @second)), 6)
RETURN @Average
END
我像这样传递日期:2013-01-01 和 2013-05-01 执行此操作时出现错误:将数字转换为数据类型 varchar 的算术溢出错误。