MOD() 是 MySQL 中一个非常基础的取模函数,用于计算两个数相除后的余数。它和你熟悉的 % 运算符在功能和性能上是完全等价的。
下面是它的核心要点:
| 方面 | 说明 |
|---|---|
| 基本语法 | MOD(N, M) 或 N % M,返回 N 除以 M 的余数。 |
| 结果符号 | 关键点 :结果的正负号由 N**(被除数)** 决定。例如: MOD(-7, 3) 的结果是 -1,而不是数学上习惯的 2。 |
| 零除数 | 若除数为 0 ,结果为 NULL。 |
| NULL处理 | 若任一参数为 NULL,结果同样为 NULL。 |
| 等价形式 | MOD(N, M) 与 N % M 完全等价,可按个人习惯使用。 |
| 适用类型 | 支持整数 和浮点数运算。 |
💡 核心应用示例
- 判断奇偶 :WHERE MOD(column, 2) = 0 筛选偶数,这是取模最基础的应用。
- 数据分桶 :SELECT MOD(id, 10) AS bucket 可以将 id 均匀分配到 0-9 的10个桶中。
- 周期筛选 :WHERE MOD(id, 4) = 0 可以筛选出每4条中的第1条,实现周期采样。
- 条件聚合 :
sql
SELECT
IF(MOD(order_id, 2), '奇数订单', '偶数订单') AS order_type,
COUNT(*)
FROM orders
GROUP BY order_type;