---SQL四舍五入问题1:
SELECT CAST('123.456' as decimal) ---123 将会得到 123(小数点后面的将会被省略掉)。
---如果希望得到小数点后面的两位。则需要把上面的改为
SELECT CAST('123.456' as decimal(38, 2)) ----123.46---自动四舍五入了! ---SQL四舍五入问题2:
SELECT ROUND(123.75633, 2, 1) ---123.75000
SELECT ROUND(123.75633, 2) ---123.76000
--因为前者在进行四舍五入之前,小数点后已经被截取,保留了2位。
--而后者则没有被截取,四舍五入时自然就会得到123.76000 ROUND --返回数字表达式并四舍五入为指定的长度或精度。
ROUND ( numeric_e-xpression , length [ , function ] )
--参数numeric_e-xpression
--精确数字或近似数字数据类型类别的表达式(bit 数据类型除外)。 --length是 numeric_e-xpression 将要四舍五入的精度。length 必须是 tinyint、smallint 或int。
--当 length 为正数时,numeric_e-xpression 四舍五入为 length 所指定的小数位数。
--当 length 为负数时,numeric_e-xpression 则按 length 所指定的在小数点的左边四舍五入。
--function是要执行的操作类型。function 必须是 tinyint、smallint 或 int。如果省略 function 或 function 的值为 0(默认),numeric_e-xpression 将四舍五入。当指定 0 以外的值时,将截断 numeric_e-xpression。
--返回类型返回与 numeric_e-xpression 相同的类型。
--注释ROUND 始终返回一个值。如果 length 是负数且大于小数点前的数字个数,ROUND 将返回 0。
--示例 结果
SELECT ROUND(748.58, -4) --0 当 length 是负数时,无论什么数据类型,ROUND 都将返回一个四舍五入的 numeric_e-xpression。 示例 结果
ROUND(748.58, -1) 750.00
ROUND(748.58, -2) 700.00
ROUND(748.58, -3) 1000.00 示例
A. 使用 ROUND 和估计值
下例显示两个表达式,说明使用 ROUND 函数且最后一个数字始终是估计值。 Select ROUND(123.9994, 3), ROUND(123.9995, 3)
Go 下面是结果集: ----------- -----------
123.9990 124.0000 B. 使用 ROUND 和四舍五入的近似值
下例显示四舍五入和近似值。 语句 结果
Select ROUND(123.4545, 2)
123.4500 Select ROUND(123.45, -2)
100.00 C. 使用 ROUND 截断
下例使用两个 Select 语句说明四舍五入和截断之间的区别。第一个语句四舍五入结果。第二个语句截断结果。 语句 结果
Select ROUND(150.75, 0)
151.00 Select ROUND(150.75, 0, 1)
150.00

  

---SQL四舍五入问题1:
SELECT CAST('123.456' as decimal) ---123 将会得到 123(小数点后面的将会被省略掉)。
---如果希望得到小数点后面的两位。则需要把上面的改为
SELECT CAST('123.456' as decimal(38, 2)) ----123.46---自动四舍五入了!

---SQL四舍五入问题2:
SELECT ROUND(123.75633, 2, 1) ---123.75000
SELECT ROUND(123.75633, 2) ---123.76000
--因为前者在进行四舍五入之前,小数点后已经被截取,保留了2位。
--而后者则没有被截取,四舍五入时自然就会得到123.76000

ROUND --返回数字表达式并四舍五入为指定的长度或精度。
ROUND ( numeric_e-xpression , length [ , function ] )
--参数numeric_e-xpression
--精确数字或近似数字数据类型类别的表达式(bit 数据类型除外)。

--length是 numeric_e-xpression 将要四舍五入的精度。length 必须是 tinyint、smallint 或int。
--当 length 为正数时,numeric_e-xpression 四舍五入为 length 所指定的小数位数。
--当 length 为负数时,numeric_e-xpression 则按 length 所指定的在小数点的左边四舍五入。
--function是要执行的操作类型。function 必须是 tinyint、smallint 或 int。如果省略 function 或 function 的值为 0(默认),numeric_e-xpression 将四舍五入。当指定 0 以外的值时,将截断 numeric_e-xpression。
--返回类型返回与 numeric_e-xpression 相同的类型。
--注释ROUND 始终返回一个值。如果 length 是负数且大于小数点前的数字个数,ROUND 将返回 0。
--示例 结果
SELECT ROUND(748.58, -4) --0

当 length 是负数时,无论什么数据类型,ROUND 都将返回一个四舍五入的 numeric_e-xpression。

示例 结果
ROUND(748.58, -1) 750.00
ROUND(748.58, -2) 700.00
ROUND(748.58, -3) 1000.00

示例
A. 使用 ROUND 和估计值
下例显示两个表达式,说明使用 ROUND 函数且最后一个数字始终是估计值。

Select ROUND(123.9994, 3), ROUND(123.9995, 3)
Go

下面是结果集:

----------- -----------
123.9990 124.0000

B. 使用 ROUND 和四舍五入的近似值
下例显示四舍五入和近似值。

语句 结果
Select ROUND(123.4545, 2)
123.4500

Select ROUND(123.45, -2)
100.00

C. 使用 ROUND 截断
下例使用两个 Select 语句说明四舍五入和截断之间的区别。第一个语句四舍五入结果。第二个语句截断结果。

语句 结果
Select ROUND(150.75, 0)
151.00

Select ROUND(150.75, 0, 1)
150.00

SQLServer中round函数的更多相关文章

  1. 【转载】C#常用数据库Sqlserver中DATEPART() 函数

    在Sqlserver数据库中,DATEPART() 函数用于返回日期/时间的单独部分,比如年.月.日.小时.分钟等等.DatePart()函数的语法为: DATEPART(datepart,date) ...

  2. 【转载】 Sqlserver中DateAdd()函数

    在Sqlserver数据库中,DATEADD() 函数在日期中添加或减去指定的时间间隔.例如计算当前时间往后一天的时刻以及往前1天的时刻时间即可使用DateAdd()函数来操作,DateAdd()函数 ...

  3. 松软科技web课堂:SQLServer之ROUND() 函数

    ROUND() 函数 ROUND 函数用于把数值字段舍入为指定的小数位数. SQL ROUND() 语法 SELECT ROUND(column_name,decimals) FROM table_n ...

  4. C#中ROUND函数的问题 解决

    ROUND()是C#中math的一个成员函数.System.Math.Round(),这个函数有四种用法,最长用的是对小数点位数的舍入.但这和现实生活中的“四舍五入”有一定区别,也有别JAVA中Mat ...

  5. sqlserver中分区函数 partition by的用法

    partition  by关键字是分析性函数的一部分,它和聚合函数(如group by)不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录, partition  by ...

  6. sqlserver中分区函数 partition by与 group by 区别 删除关键字段重复列

    partition  by关键字是分析性函数的一部分,它和聚合函数(如group by)不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录, partition  by ...

  7. SQLServer中merge函数用法详解

    http://www.jb51.net/article/75302.htm Merge关键字是一个神奇的DML关键字.它在SQL Server 2008被引入,它能将Insert,Update,Del ...

  8. sqlserver中自定义函数+存储过程实现批量删除

    由于项目的需要,很多模块都要实现批量删除的功能.为了方便模块的调用,把批量删除方法写成自定义函数.直接上代码. 自定义函数: ALTER FUNCTION [dbo].[func_SplitById] ...

  9. Sqlserver中Over函数

    Over函数不能单独使用,要和分析函数:rank(),dense_rank(),row_number()等一起使用.  其参数:over(partition by columnname1 order ...

随机推荐

  1. Linux文本编辑器快捷方式

  2. mysql查询表基本操作

    数据库表的创建create table <表名>( <列名> <数据类型及长度> [not null], <列名> <数据类型及长度>, . ...

  3. UVA 103

    /* 这题说的的是 N 维的坐标, 每个盒子的N维坐标 可以进行 随意方式的调换 然后求出 A全部的坐标小于B的 则 A 可以嵌套在B中 然后 计算出最多的 盒子嵌套个数 简单的状态转移 我为何如此的 ...

  4. [WPF]WPF开发方法论

    纵观Windows GUI应用程序开发方法,从Windows API.MFC到Visual Basic再到.NET Framework,WPF的开发方法论是在.NET Framework方法论的基础上 ...

  5. tomcat启动失败问题排除及解决办法 Server Tomcat v7.0 Server at localhost failed to start.

    tomcat启动失败问题排除及解决办法 Server Tomcat v7.0 Server at localhost failed to start. 导致上面问题的原因可能有很多种,每种的解决办法都 ...

  6. 解决window.open被拦截问题

    最近在项目中有一个在浏览器中新开一个窗口的需求,如果不需要做任何的判断,只是直接新开窗口的话,用a标签即可. 但是如果需要做一些判断再新开一个窗口的话,就不能使用a标签了.window.open确实可 ...

  7. SNMP学习笔记之iReasoning MIB Browser

    0x00 MIB Browser iReasoning MIB浏览器是一个强大和易于使用的工具由iReasoning SNMP API提供支持. MIB浏览器是工程师管理启用SNMP的网络设备和应用程 ...

  8. Linux服务器上Tomcat的Web工程部署

    Linux服务器上Tomcat的Web工程部署 部署Web应用到Tomcat服务器就是将开放好的JavaWeb应用打包成war包,然后发布到tomcat服务器的webapps目录下: 步骤1,先进入t ...

  9. 20145216史婧瑶《网络对抗》Web安全基础实践

    20145216史婧瑶<网络对抗>Web安全基础实践 实验问题回答 (1)SQL注入攻击原理,如何防御 攻击原理: SQL注入攻击指的是通过构建特殊的输入作为参数传入web应用程序,而这些 ...

  10. Cron表达式详解和表达式的验证

    本篇不算原创,因为主要内容来自网上的博客,所以给出我参考文章的链接. 本文cron表达式详解的大部分内容参考了[cron表达式详解]和Quartz使用总结.Cron表达式 这两篇文章. cron校验的 ...