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)

  • 相关阅读:
    .NET Core使用RabbitMQ
    微信openid和unionid区别
    .Net Core 中GC的工作原理
    .Net Core服务监控报警指标上报Prometheus+Grafana
    .Net Core基础的健康检查
    了解数据库的四种隔离级别
    IdentityServer使用ssl证书生成token
    IdentityServer客户端授权模式
    IdentityServer用户名密码模式
    IdentityServer4学习笔记汇总(实现传送门在底部)
  • 原文地址:https://www.cnblogs.com/lgx5/p/7642892.html
Copyright © 2011-2022 走看看