Sql中的小数点和保留位数
直接上代码
首先明确:
1.round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位。 2.numeric 函数的2个参数,第一个表示数据长度,第二个参数表示小数点后位数。
3.CAST()函数和CONVERT()函数都不能执行四舍五入或截断操作。
虽然说CAST不支持四舍五入,但是有的还是执行了四舍五入了:
select cast('12.239' as decimal(5,2))--12.24
反正,遇到四舍五入还是用Round吧
例子
--decimal(32,3) 这里的'3'是你要保留的位数 select cast('12.362222' as decimal(32,3))--》12.362 --round('数字','四舍五入后保留小数点后几位') select round(122.5255,2)--122.5300 --然后用cast('数字' as 目标类型(一共多长,小数点后保留多少位) ) --numeric基本等同于Decimal select cast(round(122.5255,2) as numeric(5,2))--这个就是将122.5300这个,保留全部是5,小数点后是2 122.53 select cast('12.3898989' as decimal(32,20))--》12.38989890000000000000 SELECT CAST('12.56' AS decimal(10,8))--==>12.56000000 --比如下面这个 12.56,decimal全长是要保持10,小数点后要保留8个 --这里最多是8, 因为12已经占去2位,小数点最多是8个 SELECT CAST('12.56' AS decimal(10,8))--12.56000000
SELECT CAST('12' AS int)-->12 SELECT CAST('12.0' AS int)-->报错,double类型的字符串不能转成int
SELECT (Round(cast('12.36' as decimal(32,2)) * cast('1.23' as decimal(32,2)),2))--》15.2000
" * "代表 +-*/
人各有命,上天注定,有人天生为王,有人落草为寇。脚下的路,如果不是你自己的选择,那么旅程的终点在哪,也没人知道。你会走到哪,会遇到谁,都不一定。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2019-08-07 读取Core下的appsettings.json的值的时候中文乱码
2018-08-07 SET QUOTED_IDENTIFIER ON