問題:
客戶要求,跟金額相關的數據,打印出來要保留兩位小數,比如:13.2/13.200要顯示為13.20;
分析:
首先查看數據庫中的數據定義,均為decimal(12,2) ,直接通過數據庫查詢的結果也會保留兩位小數,但是代碼處理后,卻會忽略掉最后一個“零”位。
此處有兩個解決方案:
一、 代碼中處理,檢測到為金額字段,做特殊處理;二、修改查詢SQL語句去規避此問題; 第一種方法,無論通過數據類型還是字段名稱,都不好判斷是否為金額,故選用第二種方法。
SQL中保留兩位小數的方法有三種,(第2、3種方法類似):
1、使用ROUND()函數,ROUND返回一個數值,舍入到指定的長度或精度,使用示例:
SELECT ROUND(123.9994, 3) --123.9990 SELECT ROUND(123.9995, 3) --124.0000 SELECT ROUND(748.584, -1) --750.000 SELECT ROUND(748.586, -2) --700.000 SELECT ROUND(748.586, -3) --Error 將expression轉換為數據類型 numeric 時出現算術溢出錯誤 SELECT ROUND(748.586, -4) --0.000,如果length為負數,並且大於小數點前的數字個數,則ROUND將返回 0 SELECT ROUND(151.75, 0,0) --152.00 舍入 SELECT ROUND(151.75, 0,1) --151.00 截斷
2、使用CONVERT()函數,使用示例:
SELECT CONVERT(DECIMAL(13,2),13.123) --13.12
3、使用CAST()函數,使用示例:
SELECT CAST(13.123 as DECIMAL(13,2)) --13.12
這三種方法(其實是兩種),還是有區別的,區別在於ROUND()只是進行四舍五入,仍然會保留后面的位數為0,但是convert()和cast() 卻會截斷后面的位數,示例:
SELECT CONVERT(DECIMAL(13,2),13.123) --13.12 SELECT CAST(13.123 as DECIMAL(13,2)) --13.12 SELECT ROUND(13.123,2) --13.120
根據需求這里采用第2種方案,但是僅這樣處理還是不夠的,返回的float型,經過代碼處理后,仍然會舍去最后的"0"位。
最終的解決方案為:數據庫查詢時,把float型數據轉換為字符型,再交由代碼處理返回給客戶端。
具體實現為:
SELECT RTRIM(CONVERT(DECIMAL(13,2),13.123))
附RTRIM()的用法,返回刪除了尾隨空格的字符表達式。:
RTRIM(character expression)
示例:
SELECT RTRIM('Hello ')+'%' --Hello% SELECT RTRIM('Hello')+'%' --Hello% SELECT RTRIM('hello ' + '' + 'world ')+'%' --helloworld% SELECT RTRIM('hello ' + '' + 'world ')+'%' --hello world% SELECT RTRIM('hello' + ' ' + 'world ')+'%' --hello world%