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();
運作結果:
作者:授客
QQ:1033553122
全國軟體測試QQ交流群:7156436
Git位址:https://gitee.com/ishouke
友情提示:限于時間倉促,文中可能存在錯誤,歡迎指正、評論!
作者五行缺錢,如果覺得文章對您有幫助,請掃描下邊的二維碼打賞作者,金額随意,您的支援将是我繼續創作的源動力,打賞後如有任何疑問,請聯系我!!!
微信打賞
支付寶打賞 全國軟體測試交流QQ群