SQL Server ->> 利用CONVERT/STR/FORMAT函数把浮点型数据格式化/转换成字符串

在SQL Server中,将浮点型和整型数据转换为字符串时,可能会出现科学记数法的显示问题。本文介绍了三种避免此问题的方法:1) 使用STR函数,但需要额外清理空格和多余的0;2) 使用CONVERT/CAST转换为DECIMAL,但仍会有尾部0的问题;3) 使用SQL Server 2012的FORMAT函数,这是最简洁的选择。建议避免使用REAL数据类型,因为其精度较低。
摘要由CSDN通过智能技术生成

在SQL Server下想把数字(包括浮点型和整型)转换成字符串,保留数据原本的样子或者根据需要转换成另外指定的格式可能就不仅仅是一条CAST(XXXX AS NVARCHAR)这么简单的事情了。

无论是CAST或者CONVERT在转换FLOAT或者REAL类型成为字符串的时候都可能面临一个问题,就是最终的数据会编程科学记数法的形式出现在最终结果集中。而DECIMAL是没有遇到这个问题。

比如:

DECLARE @FL AS FLOAT
DECLARE @RL AS REAL
DECLARE @DC AS DECIMAL(18,2)

SET @FL = 1234567.89
SET @RL = 1234567.89
SET @DC = 1234567.89

SELECT    CAST(@FL AS NVARCHAR) AS FLOAT_BY_CAST, 
        CONVERT(NVARCHAR, @FL) AS FLOAT_BY_CONVERT,
        CAST(@RL AS NVARCHAR) AS REAL_BY_CAST, 
        CONVERT(NVARCHAR, @RL) AS REAL_BY_CONVERT,
        CAST(@DC AS NVARCHAR) AS DECIMAL_BY_CAST, 
        CONVERT(NVARCHAR, @DC) AS DECIMAL_BY_CONVERT

结果

FLOAT_BY_CAST                  FLOAT_BY_CONVERT               REAL_BY_CAST                   REAL_BY_CONVERT                DECIMAL_BY_CAST                DECIMAL_BY_CONVERT
------------------------------ ------------------------------ ------------------------------ ------------------------------ ------------------------------ ------------------------------
1.23457e+006                   1.23457e+006                   1.23457e+006                   1.23457e+006                   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值