格式化数字为指定位数

-- =============================================
-- Create date: 2019-1-24
-- Description:    格式化数字为指定位数(如果有小数则四舍五入,例如当@Place=2, 则555.5560444=555.56, 555=555.00)
-- =============================================
CREATE FUNCTION [dbo].[F_FormatDecimalWithPattern] 
(
    @Number    VARCHAR(100), --数字
    @Place        INT, --转化的位数
    @DefaultPattern    NVARCHAR(100) --如果无法转换为数字,则返回默认的字符串
)
RETURNS VARCHAR(100)
AS
BEGIN

    IF ISNUMERIC(@Number) = 0
        RETURN @DefaultPattern
    
    DECLARE    @Value DECIMAL(18,8),
                @ReturnValue VARCHAR(100)
    
    SET @Value = CONVERT(DECIMAL(18,8), @Number)
    
    SET @ReturnValue = ROUND(@Value, @Place)
    SET @ReturnValue = CONVERT(VARCHAR(100), @ReturnValue)

    SET @ReturnValue = LEFT(@ReturnValue, LEN(@ReturnValue) - 8 + @Place)

    RETURN @ReturnValue
END

GO

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值