zoukankan      html  css  js  c++  java
  • sqlserver把小数点后面多余的0去掉

    Sql中想把小数点后多余的0去掉,怎么办?

    select 5000/10000.0 --想变成0.5
    select 5500/10000.0 --想变成0.55
    select 5550/10000.0 --想变成0.555
    select 5555/10000.0 --想变成0.5555

    其结果分别为:0.5000000    0.5500000  0.5550000   0.5555000

    一、如果想去掉数字5后面多余的0 ,需要转化一下:

    select CONVERT(FLOAT,5000/10000.0) --想变成0.5
    select CONVERT(FLOAT,5500/10000.0) --想变成0.55
    select CONVERT(FLOAT,5550/10000.0) --想变成0.555
    select CONVERT(FLOAT,5555/10000.0) --想变成0.5555

    其结果分别为: 0.5  0.55  0.555 0.5555

    二、创建函数:

    在sql server 建个函数ClearZero,使用这个函数去掉小数点后面多余的零。

     CREATE function [dbo].[ClearZero](@inValue varchar(50))
    returns varchar(50)
    as
    begin
    declare @returnValue varchar(20)
    if(@inValue='')
       set @returnValue='' --空的时候为空
    else if (charindex('.',@inValue) ='0')
       set @returnValue=@inValue --针对不含小数点的
    else if ( substring(reverse(@inValue),patindex('%[^0]%',reverse(@inValue)),1)='.')
              set @returnValue =left(@inValue,len(@inValue)-patindex('%[^0]%',reverse(@inValue))) --针对小数点后全是0的
          else
              set @returnValue =left(@inValue,len(@inValue)- patindex('%[^0]%.%',reverse(@inValue))+1) --其他任何情形
    return @returnValue
    end

    另: 在c#中呢?

    decimal d = 0.0500m;

    d.ToString("0.##")就出来了

    也可以这样 string.Format("{0:0.##}",d000)

  • 相关阅读:
    PHP断点续传(下载)代码
    PHP及相关服务器防盗链
    工作过程中注意事项(一)
    ubuntu下libtorrent库安装
    ubuntu ftp 服务器搭建
    ubuntu系统搭建php+apache+cumulusclips
    JavaScript HTML DOM 元素(节点)
    JavaScript 闭包
    安装安卓(Android)x86系统
    javascript 错误与调试
  • 原文地址:https://www.cnblogs.com/lgx5/p/7642892.html
Copyright © 2011-2022 走看看