在Teradata做数据舍入时,发现一些问题,如下例:
select cast('1234.505' as decimal(18,2))
--1234.50
select cast('1234.515' as decimal(18,2))
--1234.52
到底时怎么造成大的呢?
[@more@]查资料得知:Teradata中四舍五入的规则由DBSCONTROL下的参数 RoundHalfwayMagUp 决定,默认情况下RoundHalfwayMagUp = FALSE,意为按照Teradata的规则进行进位。当RoundHalfwayMagUp设为TRUE时,和正常的进位没有区别。Teradata的进位规则考虑的是:5是个中间值,进位或不进位都欠妥。因此他采取一种折中处理方法:1、当5后面有1位不为0时,则进位;
2、当5后面位都为0或者没有其他位时根据5前面一位的奇偶,奇进偶不进,下面是一些例子:
select cast('1234.505' as decimal(18,2))
--1234.50
select cast('1234.515' as decimal(18,2))
--1234.52
select cast('1234.5051' as decimal(18,2))
--1234.51
select cast('1234.5052' as decimal(18,2))
--1234.51
select cast('1234.505001' as decimal(18,2))
--1234.51
select cast('1234.50500' as decimal(18,2))
--1234.50
select cast('1234.51500' as decimal(18,2))
--1234.52
select cast('1234.52500' as decimal(18,2))
--1234.52
设置RoundHalfwayMagUp = true,(设置成功需要重启数据库才能生效)则按标准的四舍五入进行取舍。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/16723161/viewspace-1034200/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/16723161/viewspace-1034200/