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;
相关推荐
ejinxian39 分钟前
PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, OceanBase, Sql Server等数据库
数据库·mysql·mongodb
折哥的程序人生 · 物流技术专研7 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
AOwhisky7 小时前
Redis 学习笔记(第三期):持久化与主从复制
运维·数据库·redis·笔记·学习·云计算
李白的天不白7 小时前
数据库连接报错问题
数据库
一条泥憨鱼7 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
爱喝水的鱼丶8 小时前
SAP-ABAP:SAP视图开发入门:四类标准视图的适用场景与创建步骤详解
服务器·数据库·性能优化·sap·abap
大白要努力!8 小时前
MySQL 8.0 + Navicat 完整操作指南
数据库·mysql
云絮.9 小时前
数据库操作
数据库·mysql·算法·oracle
小小工匠9 小时前
Redis 缓存替换策略:8 种淘汰策略与 LRU 实现剖析
数据库·redis·缓存