这实际上是一个(不是很优雅的)解决方案,当我从 dummy_table 与一些捏造的数据总计进行联合时,我试图将浮点数返回到 varchar 列。
为了将浮点数转换为字符串,我在 SQL Server 2008(我在 SO 上找到)中使用了以下函数:
str(sum(<float_column>),25,5)
这留下了很多前导空格和尾随零,这是不可取的。我使用以下字符串来测试带有虚拟表的格式(请注意,前面有 24 个空格未显示):
- '8.50000'
- '0.50000'
- '8.00000'
我使用以下函数来获得所需的格式:
select replace(rtrim(replace(replace(rtrim(replace(ltrim(
' 8.0000'),'0',' ')),' ','0'),'.',' ')),' ','.') from dummy_table;
这按以下顺序工作:
- LTRIM 修剪左侧的空白区域。
- 用空格替换所有零。
- RTRIM 从右侧修剪这些空白区域。
- 用零替换所有空格。
- 用空格替换点。
- 从右侧修剪所有空间(如果存在,则删除尾随点)。
- 用点替换空格(如果存在,将点放在正确的位置)。
如果你们能想到更好的方法,请告诉我!