1. 程式人生 > >sql求平均,入庫,取整

sql求平均,入庫,取整

insert into [dbo].[T_MON_AIRSTATIONDAY]
(STATIONCODE,MONIDATE,PM25)
select STATIONCODE,substring(convert(varchar,MONIDATE,120),0,11) MONIDATE,
cast(round(avg(PM25),0) as int)   PM25
from  [dbo].[T_MON_AIRSTATIONHOUR]
where MONIDATE<'2018-3-20'
group by STATIONCODE,substring(convert(varchar,MONIDATE,120),0,11) 

 

 

【1】取整

cast(round(avg(PM25),0) as int)   PM25

【2】日期擷取

substring(convert(varchar,MONIDATE,120),0,11) 

https://www.cnblogs.com/yangdunqin/p/sql_CEILING.html

知識無限

Sql 獲取向上取整、向下取整、四捨五入取整的例項


【四捨五入取整擷取】

select round(54.56,0)

 【向下取整擷取】

SELECT FLOOR(54.56)

 【向上取整擷取】

 SELECT   CEILING(13.15)

--MSSQL取整函式的使用

--兩個整數相除將截斷小數部分 
select 3/4,4/3,5/3 
--結果 0,1,1 
 
--返回大於或等於所給數字表達式的最小整數 
SELECT CEILING(123.55), CEILING(123.45),CEILING(-123.45), CEILING(0.0) 
--結果 124,124,-123,0 
 -- www.2cto.com  
--四捨五入 round(a,b) -- 結果a 精確到小數點右 b位,或是左 -b位
select round(54.36,-2), round(54.36,-1),round(54.36,0), round(54.36,1),round(54.36,2) 
--結果 100.00,50.00,54.00,54.40,54.36 
 
---四捨五入 並轉化為 整數 
select cast(round(56.361,0) as int),cast(round(56.561,0) as int) 
--結果 56,57 
 
--舉例使用 
 
---兩個整數相除 捨棄小數部分( 全部都向前進位) 
declare @dividend decimal(20,2), @divisor decimal(20,2) 
 
set @dividend=3 
set @divisor=4 
select CEILING(@dividend/@divisor) 
--結果 1 
 
set @dividend=4 
set @divisor=3 
select CEILING(@dividend/@divisor) 
--結果 2 
 
set @dividend=5 
set @divisor=3 
select CEILING(@dividend/@divisor) 
--結果 2 


---兩個整數相除 四捨五入到整數 
set @dividend=3 
set @divisor=4 
select cast(round(@dividend/@divisor,0) as int) 
--結果 1 
 
set @dividend=4 
set @divisor=3 
select cast(round(@dividend/@divisor,0) as int) 
--結果 1 
 
set @dividend=5 
set @divisor=3 
select cast(round(@dividend/@divisor,0) as int) 

--結果 2

 

 【四捨五入取整擷取】

select round(54.56,0)

【向下取整擷取】

SELECT FLOOR(54.56)

 

【向上取整擷取】

 SELECT   CEILING(13.15)