mysql之sql查詢結果集小數保留

 引用:https://www.cnblogs.com/QscTiger/p/5440294.htmlhtml

 客戶要求,跟金額相關的數據,打印出來要保留兩位小數,好比:13.2/13.200要顯示爲13.20;數據庫

分析:express

首先查看數據庫中的數據定義,均爲decimal(12,2) ,直接經過數據庫查詢的結果也會保留兩位小數,可是代碼處理後,卻會忽略掉最後一個「零」位。函數

此處有兩個解決方案:spa

  1、 代碼中處理,檢測到爲金額字段,作特殊處理;2、修改查詢SQL語句去規避此問題; 第一種方法,不管經過數據類型仍是字段名稱,都很差判斷是否爲金額,故選用第二種方法。code

SQL中保留兩位小數的方法有三種,(第二、3種方法相似):htm

一、使用ROUND()函數,ROUND返回一個數值,舍入到指定的長度或精度,使用示例:blog

複製代碼
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 截斷
複製代碼

 

二、使用CONVERT()函數,使用示例:ci

  SELECT CONVERT(DECIMAL(13,2),13.123) --13.12 io

三、使用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

 注:必須保證顯示的位數,大於保留的小數位數,否則會出錯。

        數據最好採用varchar類型存儲。

不建議使用convert.

根據需求這裏採用第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%
相關文章
相關標籤/搜索