sql server中的rounding函数--

sql server中的rounding函数--

ID:22372256

大小:62.50 KB

页数:7页

时间:2018-10-28

sql server中的rounding函数--_第1页
sql server中的rounding函数--_第2页
sql server中的rounding函数--_第3页
sql server中的rounding函数--_第4页
sql server中的rounding函数--_第5页
资源描述:

《sql server中的rounding函数--》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、SQLServer中的Rounding函数>>  问题  最近我试着在自己的应用中使用四舍五入的值,我和我的用户在报表应用中的计算问题存在分歧。所有的代码都在T-SQL中,但是我认为报表问题与数据类型和向下取整或向上取整规则关系密切。请问您有没有这方面的高见?我想看到一些带有不同编码选项的例子。  专家解答  如果不理解基本的数据类型和四舍五入函数,那么你就可能误解四舍五入。由于数据类型的差异(比如integer,float,decimal等等),四舍五入后的值可能会不同。另外,由于在计算中使用的SQLServer舍入函数(ROUND(),CEILING(),FLOOR())

2、的差异,得到的结果值也可能会不同。因此,找到用户对四舍五入的要求接着把这些要求转化到适当的T-SQL命令中是很重要的。  让我们先从定义的角度开始:  lROUND()–四舍五入一个正数或者负数,结果为一定长度的值。  lCEILING()-返回最小的整数,使这个整数大于或等于指定数的数值运算。  lFLOOR()-返回最大整数,使这个整数小于或等于指定数的数值运算。  让我们来看看有不同数据类型的函数的结果。  ROUND(),CEILING()和FLOOR()例子例子值在这个例子中,你可以看到,在一个正整数的情况下,这三个舍入函数返回相同的值。DECLAREv

3、alueintSETvalue=6SELECTROUND(value,1)SELECTCEILING(value)SELECTFLOOR(value)666在第二个例子中,即使在一个负整数的情况下,这三个舍入函数还是返回相同的值。DECLAREvalueintSETvalue=-11SELECTROUND(value,1)SELECTCEILING(value)SELECTFLOOR(value)-11-11-11要证明整数这个观点,四舍五入是不可能的。让我们来看看一些其他的数据类型。DECLAREvalueintSETvalue=-11.5SELECTROUND(value

4、,2)SELECTCEILING(value)SELECTFLOOR(value)-11-11-11在我们的例子中,用一个小数数据类型和不同长度参数(比如1,2或者3)的舍入函数会产生不同的终值。当四舍五入这个值并且长度参数是1时,小数点后第二位的5是有意义的。另外,在小数数据类型中,CEILING和FLOOR函数也会考虑小数位,因为会得到不同的值。DECLAREvaluedecimal(10,2)SETvalue=11.05SELECTROUND(value,1)SELECTROUND(value,2)SELECTROUND(value,3)SELECTCEILING(va

5、lue)SELECTFLOOR(value)11.1011.0511.051211如同上面的例子,基于不同的长度参数,小数点后第二位的6是有意义的。DECLAREvaluedecimal(10,2)SETvalue=-14.46SELECTROUND(value,1)SELECTROUND(value,2)SELECTROUND(value,3)SELECTCEILING(value)SELECTFLOOR(value)-14.50-14.46-14.46-14-15这个例子也有助于描述四舍五入值的破坏。这个例子也证明了CEILING和FLOOR函数四舍五入成最近的函数。DE

6、CLAREvaluedecimal(10,10)SETvalue=.5432167890SELECTROUND(value,1)SELECTROUND(value,2)SELECTROUND(value,3)SELECTROUND(value,4)SELECTROUND(value,5)SELECTROUND(value,6)SELECTROUND(value,7)SELECTROUND(value,8)SELECTROUND(value,9)SELECTROUND(value,10)SELECTCEILING(value)SELECTFLOOR(value)0.500000

7、00000.54000000000.54300000000.54320000000.54322000000.54321700000.54321680000.54321679000.54321678900.543216789010在最后的例子中,你可以看到在浮点数据类型里采取与上面小数点的例子相同类型的行为。另外,CEILING和FLOOR函数四舍五入成最近的函数。DECLAREvaluefloat(10)SETvalue=.1234567890SELECTROUND(value,1)SELECTROUN

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。