MySQL MOD()函数详解

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;
相关推荐
William Dawson6 小时前
【MySQL触发器超详细实战教程|从零基础到项目生产可用(避坑+案例+跨库+逗号拆分)】
数据库·mysql
.柒宇.6 小时前
AI 掘金头条项目-新闻模块实现
数据库·后端·python·fastapi
许彰午6 小时前
我手写了一个 Java 内存数据库(四):索引引擎、SQL 解析与总结
java·数据库·sql
czlczl200209256 小时前
MySQL 中为什么我们要避免“多个范围查询”
数据库·mysql
若兰幽竹6 小时前
【HCIE-openGauss数据库认证】01 准备阶段:实验环境深度剖析与搭建指南
数据库·hcie-opengauss·华为专家级认证
杨云龙UP6 小时前
Oracle 19c多租户架构下设置用户密码永不过期及登录锁定策略说明_20260430
linux·运维·服务器·数据库·oracle
HackTorjan6 小时前
MySQL高可用架构设计与最佳实践
android·人工智能·mysql·adb·自动化
qiuyunoqy6 小时前
MySQL - 4 - mysqldump/mysqladmin/mysqlshow讲解
数据库·mysql
黑贝是条狗6 小时前
MySQL高可用设计
mysql·mysql高可用