PHP 增删改查去重有五类方法:一、数据库层面用 UNIQUE 索引、INSERT IGNORE 等;二、PHP 数组用 array_unique 等函数;三、SQL 查询用 DISTINCT、GROUP BY 或窗口函数;四、插入前校验加事务;五、更新操作确保条件精确和语法正确。

在 PHP 进行增删改查操作时,数据库中出现重复数据会导致业务逻辑错误或数据不一致。以下是几种常见的去重处理方法:
一、数据库层面去重
通过数据库约束和查询语句提前拦截或过滤重复记录,减少 PHP 层处理压力。
1、在数据表中为关键字段添加 UNIQUE 索引,例如对用户 邮箱 字段执行 ALTER TABLE users ADD UNIQUE(email)。
2、插入前使用 INSERT IGNORE 语句,当遇到唯一键冲突时自动忽略本次插入操作。
立即学习“PHP 免费学习笔记(深入)”;
3、使用 REPLACE INTO 替代 INSERT INTO,若存在主键或唯一索引冲突,则先删除原记录再插入新记录。
4、执行 SELECT 查询时配合 GROUP BY 或 DISTINCT 关键字,确保结果集无重复行。
二、PHP 数组去重
对已从数据库获取的二维数组或一维数组进行内存级去重,适用于导出、展示等场景。
1、对一维字符串或数字数组调用 array_unique() 函数,并用 array_values()重置索引。
2、对二维关联数组,先用 array_column()提取指定字段作为键名,再结合 array_unique()与 array_keys()提取不重复项。
3、使用 foreach 遍历并以特定字段为键构建临时数组,自动覆盖同键值,最后用 array_values()还原索引。
三、SQL 查询阶段去重
在编写 SELECT 语句时直接控制返回结果的唯一性,避免后续 PHP 额外处理。
1、在 SELECT 语句开头添加 DISTINCT 关键字,如 SELECT DISTINCT user_id FROM orders。
2、使用 GROUP BY 配合 聚合函数(如 MIN(id)、MAX(created_at))选取每组中的代表记录。
3、借助窗口函数 ROW_NUMBER() OVER(PARTITION BY column ORDER BY id)标记重复行序号,外层筛选序号为 1 的记录。
四、插入前校验去重
在执行 INSERT 操作前,主动查询目标记录是否存在,仅在不存在时才执行插入。
1、构造 SELECT COUNT(*)语句检查关键字段组合是否已存在。
2、将校验逻辑封装为独立函数,传入待插入数据并返回布尔值表示是否可插入。
3、在校验与插入之间加事务包裹,防止并发写入导致重复,使用 BEGIN TRANSACTION 与 COMMIT/ROLLBACK 控制。
五、更新操作中避免重复生成
UPDATE 语句本身不会新增记录,但若逻辑设计不当(如误用 INSERT ON DUPLICATE KEY UPDATE),可能引发非预期重复行为。
1、确认 UPDATE WHERE 条件足够精确,避免影响多条本不应被修改的记录。
2、使用 INSERT … ON DUPLICATE KEY UPDATE 语法时,明确指定冲突后更新哪些字段,而非全字段覆盖。
3、对批量更新场景,先用 SELECT 查出需更新的 ID 列表,再用 WHERE id IN (…)限定范围,防止误更新。