Sql 服务器回合将 5 解释为较低
Sql server round interpreting 5 as lower
我想在 sql 服务器 2012 中舍入小数,例如:
Select ROUND(1.056,2) -- returns 1.06
Select ROUND(1.055,2) -- returns 1.06
Select ROUND(1.054,2) -- returns 1.05
如何进行第二个查询 returns 1.05 四舍五入小数点后 5 小数?
Select 该字段只有 2 位数字。这将 select 高数排在第 4 位或第 5 位
select
case when right ( 'colvalue',1) > right (SUBSTRING('colValue',1,4),1)
then ROUND('colvalue',2)
else ROUND (LEFT ( 'colvalue',4) ,2) end RoundValue
您可以使用函数作为 round() 的第三个参数。如果函数 returns 0 则结果四舍五入,否则结果被截断。
-- Syntax for SQL Server and Azure SQL Database
ROUND ( numeric_expression , length [ ,function ] )
SELECT round(1.055,2,1)
编辑:
这是一个完整的例子...
create table test
(
n decimal(10,7) not null
)
GO
insert into test (n)
values
(1.050),
(1.051),
(1.052),
(1.053),
(1.054),
(1.055),
(1.056),
(1.057),
(1.058),
(1.059)
GO
select n, round(n,2,iif(n - round(n,2,1)>.005,0,1)) as rounded from test
GO
这是结果:
n rounded
1.0500000 1.0500000
1.0510000 1.0500000
1.0520000 1.0500000
1.0530000 1.0500000
1.0540000 1.0500000
1.0550000 1.0500000
1.0560000 1.0600000
1.0570000 1.0600000
1.0580000 1.0600000
1.0590000 1.0600000
你可以用这个。它会为你工作。
DECLARE @test decimal(10,3) = 1.055
SELECT CASE WHEN round(@test,3,1) - round(@test,2,1) = 0.005 THEN round(@test,2,1) ELSE round(@test,2) END
我会选择简单的:
DECLARE @test nvarchar(10)
DECLARE @test_string nvarchar(10)
SET @test_string='1.055'
-- SET @test_string='1.056' -- is here to test
SET @test = SUBSTRING(@test_string,5,5)
IF @test=5
BEGIN
SELECT ROUND (LEFT(@test_string,4),2)
END
ELSE
BEGIN
SELECT ROUND (@test_string,2)
END
尝试转换舍入值:
Select CAST(ROUND(1.056,2) AS NUMERIC(10,2)) -- returns 1.06
Select CAST(ROUND(1.055,2) AS NUMERIC(10,2)) -- returns 1.06
Select CAST(ROUND(1.054,2) AS NUMERIC(10,2)) -- returns 1.05
我想在 sql 服务器 2012 中舍入小数,例如:
Select ROUND(1.056,2) -- returns 1.06
Select ROUND(1.055,2) -- returns 1.06
Select ROUND(1.054,2) -- returns 1.05
如何进行第二个查询 returns 1.05 四舍五入小数点后 5 小数?
Select 该字段只有 2 位数字。这将 select 高数排在第 4 位或第 5 位
select
case when right ( 'colvalue',1) > right (SUBSTRING('colValue',1,4),1)
then ROUND('colvalue',2)
else ROUND (LEFT ( 'colvalue',4) ,2) end RoundValue
您可以使用函数作为 round() 的第三个参数。如果函数 returns 0 则结果四舍五入,否则结果被截断。
-- Syntax for SQL Server and Azure SQL Database
ROUND ( numeric_expression , length [ ,function ] )
SELECT round(1.055,2,1)
编辑:
这是一个完整的例子...
create table test
(
n decimal(10,7) not null
)
GO
insert into test (n)
values
(1.050),
(1.051),
(1.052),
(1.053),
(1.054),
(1.055),
(1.056),
(1.057),
(1.058),
(1.059)
GO
select n, round(n,2,iif(n - round(n,2,1)>.005,0,1)) as rounded from test
GO
这是结果:
n rounded
1.0500000 1.0500000
1.0510000 1.0500000
1.0520000 1.0500000
1.0530000 1.0500000
1.0540000 1.0500000
1.0550000 1.0500000
1.0560000 1.0600000
1.0570000 1.0600000
1.0580000 1.0600000
1.0590000 1.0600000
你可以用这个。它会为你工作。
DECLARE @test decimal(10,3) = 1.055
SELECT CASE WHEN round(@test,3,1) - round(@test,2,1) = 0.005 THEN round(@test,2,1) ELSE round(@test,2) END
我会选择简单的:
DECLARE @test nvarchar(10)
DECLARE @test_string nvarchar(10)
SET @test_string='1.055'
-- SET @test_string='1.056' -- is here to test
SET @test = SUBSTRING(@test_string,5,5)
IF @test=5
BEGIN
SELECT ROUND (LEFT(@test_string,4),2)
END
ELSE
BEGIN
SELECT ROUND (@test_string,2)
END
尝试转换舍入值:
Select CAST(ROUND(1.056,2) AS NUMERIC(10,2)) -- returns 1.06
Select CAST(ROUND(1.055,2) AS NUMERIC(10,2)) -- returns 1.06
Select CAST(ROUND(1.054,2) AS NUMERIC(10,2)) -- returns 1.05