十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
先将分子或分母或两个都转化成8小数精度以上的类型,decimal,numeric,float 都可以。
创新互联主营麻江网站建设的网络公司,主营网站建设方案,成都App定制开发,麻江h5微信平台小程序开发搭建,麻江网站营销推广欢迎麻江等地区企业咨询
然后做除法计算,将计算结果转化为8位小数。
select convert(decimal(18,8), convert(decimal(18,8),1)/3)
select convert(decimal(18,8), 1/convert(decimal(18,8),3))
select CONVERT(decimal(18,8), convert(float,1)/3)
select CONVERT(decimal(18,8), 1/convert(float,3))
写个函数就行了 很简单 主题代码如下 可在sqlserver 直接运行
declare @aaa varchar(50)='3213.434'
if (substring(@aaa ,charindex('.',@aaa)+1,LEN(@aaa)-charindex('.',@aaa)-1) 3)
begin
print cast( cast(@aaa as numeric(18,3)) as varchar(50))
end
else
print @aaa
直接运行看打印的结果, 这里是直接截取 如果要四舍五入 用round 函数。 改成函数应该不用我说了吧 加个壳 把 print 改成 return 返回出去
round返回数字表达式并四舍五入为指定的长度或精度。
显示的界面上要求只保留到小数点后4位,发现round(表达式,4,1)可以截断小数点4位后的数字
如果写(round,4)表示对小数点后4位四舍五入,但不截断多的0