sqlserver自定义函数时遇到很奇怪的问题!
编写一个四舍六入函数 ,5后一位没有数字时且其前一位是偶数时不进,其余情况四舍五入。 例子如下:(保留一位小数)
如1.25-〉1.2
1.250-〉1.3
1.15-〉1.2
1.150-〉1.2
在 sqlserver2000的查询分析器里实现没有问题,编成自定义函数却出现问题。
////
declare @str varchar(20) /*转换成字符类型*/
declare @str20 varchar(20) /*小数位数后面的字符串*/
declare @temp varchar(20)
declare @i int
declare @temp0 varchar(20)
declare @temp1 varchar(20)
set @str = '1.25 '
set @i=1
set @str20=substring(@str,charindex( '. ',@str) + 1,len(@str))
set @temp=substring(@str20,@i+1,1)
set @temp0=substring(@str20,@i,1)
set @temp1=substring(@str20,@i+2,1)
if len(@str20) <@i
begin
set @str= @str+replicate( '0 ',@i-len (substring(@str,charindex( '. ',@str)+1,len(@str))))
end
else if((@temp1= ' ')and (convert(int,@temp)=5) and (convert(int,@temp0)%2=0) )
begin
set @str=substring(@str,1,charindex( '. ',@str) +@i)
end
else
begin /*否则四舍五入*/
set @str = convert(varchar,round(convert(float,@str),@i))
end
select @str
当str赋值1.25时结果为1.2
1.250时结果为1.3
均正确
相同的代码编成自定义函数:
CREATE function tttRound(@num float,@i int)
returns float
as
begin
declare @str varchar(20) /*转换成字符类型*/
declare @str20 varchar(20) /*小数位数后面的字符串*/
declare @temp varchar(20)
declare @temp0 varchar(20)
declare @temp1 varchar(20) /*小数位数字符串*/
set @str = convert(varchar,@num)
set @str20=substring(@str,charindex( '. ',@str) + 1,len(@str))
set @temp=substring(@str20,@i+1,1)
set @temp0=substring(@str20,@i,1)
set @temp1=substring(@str20,@i+2,1)
if len(@str20) <@i
begin
set @str= @str+replicate( '0 ',@i-len (substring(@str,charindex( '. ',@str)+1,len(@str))))
end
else if((@temp1= ' ')and (convert(int,@temp)=5) and (convert(int,@temp0)%2=0) )
begin
set @str=substring(@str,1,charindex( '. ',@str) +@i)
end
else
begin /*否则四舍五入*/
set @str = convert(varchar,round(@num,@i))
end
RETURN @str
end
select dbo.tttRound(1.25,1) 结果1.2
select dbo.tttRound(1.250,1)结果竟然也是1.2
不知道哪里出问题了???
请高人指点!~
------解决方案--------------------
CREATE function tttRound(@num float --这里有问题,定义成varchar类型就没问题了
,@i int)
returns float