天天看點

MariaDB MySQL變量取值避免四舍五入的方法

MySQL變量取值避免四舍五入的方法

By:授客 QQ:1033553122

在一些對資料精确度要求比較高的場景(比如資金結算)下,變量取值時不能對變量值進行四舍五入操作,這時候就要做些預處理工作。

方法1:利用TRUNCATE(D, X)函數

方法2:利用FLOOR(X)函數

舉例說明:

DROP PROCEDURE IF EXISTS test_proc;

DELIMITER //

CREATE PROCEDURE test_proc()

BEGIN

DECLARE var_name1 DECIMAL(6, 4);  # 定義局部變量,包括小數點總的7位,小數部分占4位,整數部分最多占2位

DECLARE var_name2 DECIMAL(6, 4); 

DECLARE var_name3 DECIMAL(6, 4); 

SET var_name1 = 99.456789;

#方法1:

SET var_name2 = TRUNCATE(99.456789, 4); # TRUNCATE(D, X) X為截取的小數位數

#方法2:

SET var_name3 = FLOOR(99.456789 * 10000) / 10000; # FLOOR(X) 傳回小于X的最大整數

SELECT var_name1 AS '四舍五入後的值',

var_name2 AS '利用TRUNCATE函數截取的值',

var_name3 AS '利用FLOOR函數截取的值';

END;

//

DELIMITER ;

CALL test_proc();

運作結果:

MariaDB MySQL變量取值避免四舍五入的方法

作者:授客

QQ:1033553122

全國軟體測試QQ交流群:7156436

Git位址:https://gitee.com/ishouke

友情提示:限于時間倉促,文中可能存在錯誤,歡迎指正、評論!

作者五行缺錢,如果覺得文章對您有幫助,請掃描下邊的二維碼打賞作者,金額随意,您的支援将是我繼續創作的源動力,打賞後如有任何疑問,請聯系我!!!

           微信打賞                       

支付寶打賞                  全國軟體測試交流QQ群  

MariaDB MySQL變量取值避免四舍五入的方法
MariaDB MySQL變量取值避免四舍五入的方法
MariaDB MySQL變量取值避免四舍五入的方法

繼續閱讀