---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. mysql导入数据方法和报错解决

    mysql -u root -p databasename < db.sql 数据库导入数据时,MySQL收到下面异常:ERROR 1153 (08S01): Got a packet bigg ...

  2. webapi 返回json及route设置

    1.返回json 修改App_Start/webapiconfig public static void Register(HttpConfiguration config) { // Web API ...

  3. CoreSight介绍篇

    ARM的嵌入式IDE发展: 1)SDT,英文全称ARM SoftWare Development Kit,是ARM为方便用户在ARM芯片进行应用软件开发而推出的一整套开发工具. 2)ADS,英文全称A ...

  4. hdu5195 二分+线段树+拓扑序

    这题说的给了n个点m条边要求保证是一个有向无环图,可以删除至多k条边使得这个图的拓扑序的字典序最大,我们知道如果我们要排一个点的时候一定要考虑比他大的点是否可以.通过拆边马上拆出来,如果可以拆当然是拆 ...

  5. MySQL从删库到跑路_高级(四)——存储过程

    作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.存储过程简介 1.存储过程简介 存储过程是一组具有特定功能的SQl语句集组成的可编程的函数,经编译创建并保存在数 ...

  6. Python: re.compile最短匹配模式,只取双引号内的值\“

    用正则表达式匹配某个文本模式 1.只取双引号内的值 2.长短匹配模式对比 贪婪模式:     模式r'\"(.*)\" '的意图是匹配被双引号包含的文本,但是这个表达式中*是贪婪的 ...

  7. ubuntu14.04无法安装Curl,需要先升级sudo apt-get update

    ubuntu14.04无法安装Curl,需要先升级sudo apt-get updatesudo apt-get updatesudo apt-get install curl------------ ...

  8. mysql中join后on、where的区别

    SELECT * FROM A; SELECT * FROM B; 以上是两张表的机构 SELECT * FROM A LEFT JOIN B ON A.id=b.a_id ; ; ; 两个语句查询出 ...

  9. nginx做http向https的自动跳转

    在访问百度时,在浏览器输入www.baidu.com会自动跳转到https://www.baidu.com不用人工干预,nginx也可以做这样的自动跳转! 首先让nginx服务器监听两个端口,分别是8 ...

  10. SQL学习之SqlMap SQL注入

    sqlmap也是渗透中常用的一个注入工具,其实在注入工具方面,一个sqlmap就足够用了,只要你用的熟,秒杀各种工具,只是一个便捷性问题,sql注入另一方面就是手工党了,这个就另当别论了. 今天把我一 ...