sql中数值函数如何书写_mysql计算语法基础

6次阅读

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

sql 中数值函数如何书写_mysql 计算语法基础

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 不允许在 聚合函数 内部再调用标量函数后再用于计数上下文(除非用子查询或派生表)。

正确做法分两步:

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)会导致索引失效。真正影响性能的,往往不是函数选错,而是没意识到它让条件无法走索引。

星耀云
版权声明:本站原创文章,由 星耀云 2026-01-04发表,共计1163字。
转载说明:转载本网站任何内容,请按照转载方式正确书写本站原文地址。本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。
text=ZqhQzanResources