MySQL数值函数需带括号调用,注意NULL处理、浮点混用及索引失效;ROUND用银行家舍入,CEILING/FLOOR对负数取整方向不同;MOD与%负数结果不一致;聚合中不可直接嵌套标量函数。

MySQL 中常用数值函数怎么写
MySQL 提供的数值函数大多直接作用于列或表达式,不需要额外声明类型,但必须注意参数是否为 NULL、是否支持浮点/整型混用。比如 ABS() 对负数取绝对值,ROUND(3.14159, 2) 返回 3.14;而 ROUND(NULL) 结果仍是 NULL,不是报错。
常见写法误区是把函数当变量用,例如写成 SELECT ABS col FROM t(漏括号),正确写法必须带括号:SELECT ABS(col) FROM t。
ROUND、CEILING、FLOOR 的区别和精度陷阱
这三个函数都处理小数,但行为差异明显,容易在金额计算或分页逻辑中出错:
-
ROUND(x, d)四舍五入到d位小数,d可为负数(如ROUND(1234.56, -2)→1200) -
CEILING(x)向上取整(不小于x的最小整数),CEILING(-1.2)→-1 -
FLOOR(x)向下取整(不大于x的最大整数),FLOOR(-1.2)→-2
特别注意:MySQL 的 ROUND() 在 5 附近使用“银行家舍入”(偶数舍入),ROUND(2.5) 和 ROUND(3.5) 都返回 4,不是传统四舍五入。若需严格四舍五入,得用 CAST(ROUND(x + 0.5 - SIGN(x)*0.5) AS SIGNED) 这类绕过方式。
聚合场景下数值函数不能直接嵌套 COUNT
像 COUNT(ROUND(price)) 这种写法会报错,因为 COUNT() 只接受列名、* 或表达式,但 MySQL 不允许在聚合函数内部再调用标量函数后再用于计数上下文(除非用子查询或派生表)。
正确做法分两步:
MATLAB(矩阵实验室)是MATrix LABoratory的缩写,是一款由美国The MathWorks公司出品的商业数学软件。MATLAB是一种用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。除了矩阵运算、绘制函数/数据图像等常用功能外,MATLAB还可以用来创建用户界面及与调用其它语言(包括C,C++和FORTRAN)编写的程序。MATLAB基础知识;命令窗口是用户与MATLAB进行交互作业的主要场所,用户输入的MATLAB交互命令均在命令窗口执行。 感兴趣的朋友可以
SELECT COUNT(*) FROM ( SELECT ROUND(price) AS rprice FROM orders WHERE price IS NOT NULL ) AS t;
或者改用条件统计:COUNT(CASE WHEN price > 0 THEN 1 END) —— 这里 1 是非空值,能被 COUNT 统计。
MOD 和 % 运算符在负数时结果不一致
MySQL 中 MOD(a, b) 和 a % b 看似等价,但对负数处理不同:
-
MOD(-7, 3)→2(遵循数学定义:a - b * FLOOR(a/b)) -
-7 % 3→-1(C 语言风格取余,符号跟随被除数)
如果做分组编号(如每 5 条一组),用 MOD(id, 5) 更安全;若依赖符号一致性(比如判断奇偶),建议统一用 ABS(id) % 2 避免负 ID 导致意外。
数值函数本身不慢,但嵌套过深或在 WHERE 子句中对字段调用(如 WHERE ROUND(price) = 100)会导致索引失效。真正影响性能的,往往不是函数选错,而是没意识到它让条件无法走索引。









