1

这实际上是一个(不是很优雅的)解决方案,当我从 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;

这按以下顺序工作:

  1. LTRIM 修剪左侧的空白区域。
  2. 用空格替换所有零。
  3. RTRIM 从右侧修剪这些空白区域。
  4. 用零替换所有空格。
  5. 用空格替换点。
  6. 从右侧修剪所有空间(如果存在,则删除尾随点)。
  7. 用点替换空格(如果存在,将点放在正确的位置)。

如果你们能想到更好的方法,请告诉我!

4

1 回答 1

1

回合应该为此工作。

选择回合(8.5000000000,5)

http://sqlfiddle.com/#!3/1fa93/8845

于 2013-08-27T11:59:40.090 回答