SQL Server 中字段的精度问题

在工作中遇到,一个多表联合查询的情况,查询出来的有些字段精度太高,小数点后达到8个0,现在客户要求报表只要精确到0.01 ,就是只要小数点后面只要保存两位,另外还需要四舍五入

 

在网上找了点资料,自己测试了下,下面给大家分享下:

---创建一个测试表

USE test
CREATE TABLE studentscore
(
id INT IDENTITY(1,1) PRIMARY KEY ,
Score VARCHAR(20)
)
下面是截图,插入这些数据
 

1.不改变表中的值,只在查询时显示,四舍五入只保留两位小数

select Convert(decimal(18,2), Score) from studentscore
 
执行结果:

2.直接更新表中的值,四舍五入只保留两位小数

update studentscore set Score = cast(cast(round(Score,2) as float ) as varchar)
where charindex('.',REVERSE(cast(Score as varchar(50))))-1>3
 
更新后的数据库:

 

 

转载于:https://www.cnblogs.com/kelly1314/p/7244884.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值