国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

sqlserver四舍五入使用round函數(shù)及cast和convert函數(shù)

2020-07-25 12:49:16
字體:
供稿:網(wǎng)友

引言

      今天和測試溝通一個百分比計算方式時遇到一個問題, 我在存儲過程里用到了強(qiáng)轉(zhuǎn)CAST(32.678 AS DECIMAL(5,1))  我認(rèn)為該方式只會保留一位小數(shù),我給測試的回復(fù)是我并沒有用到四舍五入函數(shù),數(shù)據(jù)也沒有四舍五入,而測試說他們自己驗(yàn)證后覺的數(shù)據(jù)是經(jīng)過四舍五入了的。 想到這里于是我再試了試存儲過程的每個計算點(diǎn),才發(fā)現(xiàn)了這個問題。

ROUND

     那么用到四舍五入并且保留小數(shù)點(diǎn)時我們肯定會首選ROUND函數(shù),  如果字段的數(shù)據(jù)類型是decimal(18,10)時那么四舍五入后還會有很多0出現(xiàn)。

CAST和CONVERT

    其實(shí)我使用強(qiáng)轉(zhuǎn)時并沒有打算四舍五入結(jié)果,只是單純?yōu)榱说玫椒衔乙蟮臄?shù)據(jù),今天才發(fā)現(xiàn)這兩個強(qiáng)轉(zhuǎn)也會四舍五入結(jié)果,也就是說下面三個語句將會返回相同的結(jié)果值

select ROUND(32.678,1)  --32.700select CAST(32.678 as DECIMAL(5,1)) --32.7select convert(NUMERIC(5,1),32.678) --32.7

下面抽個空給大家介紹SQL的四舍五入ROUND函數(shù)

SQL四舍五入2007/11/01 16:35問題1:

SELECT CAST('123.456' as decimal) 

將會得到 123(小數(shù)點(diǎn)后面的將會被省略掉)。

如果希望得到小數(shù)點(diǎn)后面的兩位。

則需要把上面的改為

SELECT CAST('123.456' as decimal(38, 2)) ===>123.46

自動四舍五入了!

問題2:

SELECT ROUND(123.75633, 2, 1), ROUND(123.75633, 2)

上面的SQL得到的2個值是不一樣的,前一個是:123.75000,后一個是:123.76000。

因?yàn)榍罢咴谶M(jìn)行四舍五入之前,小數(shù)點(diǎn)后已經(jīng)被截取,保留了2位。

而后者則沒有被截取,四舍五入時自然就會得到123.76000

ROUND

返回數(shù)字表達(dá)式并四舍五入為指定的長度或精度。

語法

ROUND ( numeric_e-xpression , length [ , function ] )

參數(shù)

numeric_e-xpression

精確數(shù)字或近似數(shù)字?jǐn)?shù)據(jù)類型類別的表達(dá)式(bit 數(shù)據(jù)類型除外)。

length

是 numeric_e-xpression 將要四舍五入的精度。length 必須是 tinyint、smallint 或int。當(dāng) length 為正數(shù)時,numeric_e-xpression 四舍五入為 length 所指定的小數(shù)位數(shù)。當(dāng) length 為負(fù)數(shù)時,numeric_e-xpression 則按 length 所指定的在小數(shù)點(diǎn)的左邊四舍五入。

function

是要執(zhí)行的操作類型。function 必須是 tinyint、smallint 或 int。如果省略 function 或 function 的值為 0(默認(rèn)),numeric_e-xpression 將四舍五入。當(dāng)指定 0 以外的值時,將截斷 numeric_e-xpression。

返回類型

返回與 numeric_e-xpression 相同的類型。

注釋

ROUND 始終返回一個值。如果 length 是負(fù)數(shù)且大于小數(shù)點(diǎn)前的數(shù)字個數(shù),ROUND 將返回 0。

示例 結(jié)果

ROUND(748.58, -4) 0

當(dāng) length 是負(fù)數(shù)時,無論什么數(shù)據(jù)類型,ROUND 都將返回一個四舍五入的 numeric_e-xpression。

示例 結(jié)果

ROUND(748.58, -1) 750.00
ROUND(748.58, -2) 700.00
ROUND(748.58, -3) 1000.00

示例

A. 使用 ROUND 和估計值

下例顯示兩個表達(dá)式,說明使用 ROUND 函數(shù)且最后一個數(shù)字始終是估計值。

Select ROUND(123.9994, 3), ROUND(123.9995, 3) GO

下面是結(jié)果集:

----------- -----------
123.9990    124.0000 

B. 使用 ROUND 和四舍五入的近似值

下例顯示四舍五入和近似值。

語句 結(jié)果

Select ROUND(123.4545, 2)
123.4500
Select ROUND(123.45, -2)
100.00

C. 使用 ROUND 截斷

下例使用兩個 Select 語句說明四舍五入和截斷之間的區(qū)別。第一個語句四舍五入結(jié)果。第二個語句截斷結(jié)果。

語句 結(jié)果

Select ROUND(150.75, 0)151.00Select ROUND(150.75, 0, 1)150.00
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 遵义县| 故城县| 临澧县| 兴安盟| 卢湾区| 榆林市| 浦县| 华池县| 济阳县| 汝南县| 锦州市| 长寿区| 上饶市| 惠安县| 房产| 高唐县| 镶黄旗| 浮梁县| 新营市| 精河县| 漳平市| 南宁市| 环江| 公主岭市| 罗甸县| 阿拉善盟| 台南市| 五寨县| 榆树市| 航空| 宜兰县| 云南省| 新泰市| 湘潭县| 龙井市| 九龙城区| 林西县| 武宁县| 邳州市| 石狮市| 伊金霍洛旗|