如何在 PHP 中高效去除关联数组中重复的任务值 本文介绍两种在 PHP 中去除多维数组内重复任务值的实用方法:使用 array_unique() 函数去重,或在插入前通过 in_array() 判断避免重复添加,适用于从数据库批量查询后需去重的场景。 在 PHP 开发中,处理从数据库查询出的数据是

本文介绍两种在 PHP 中去除多维数组内重复任务值的实用方法:使用 array_unique() 函数去重,或在插入前通过 in_array() 判断避免重复添加,适用于从数据库批量查询后需去重的场景。
在 PHP 开发中,处理从数据库查询出的数据是常见操作。一个典型场景是:根据用户的多个角色动态查询对应的任务列表,并将这些任务聚合到一个以员工 ID 为键的关联数组中。这个过程看似简单,但问题常在于:当多个角色关联到同一任务时(例如任务“21”和“22”被多次查询到),最终生成的数组会包含大量重复项。这会导致数据冗余,并可能影响后续的业务逻辑处理和前端展示。
长期稳定更新的攒劲资源: >>>点此立即查看<<<
针对此问题,下面介绍两种专业且易于维护的解决方案,帮助您高效清理数据。
这是最清晰、最稳妥的方法,尤其在处理较大结果集时性能表现稳定。核心思路分为三步:将所有任务收集到临时数组,统一去重,最后赋值回原数组。具体实现如下:
function Job($conn) {
$array = [];
// 确保角色 ID 无重复(防止 SQL 重复执行)
$uniqueRoles = array_unique($_SESSION['ROLES']);
foreach ($uniqueRoles as $roleId) {
$sql = "SELECT employee, task FROM table WHERE id = ? AND employee = 24";
// 强烈建议使用预处理语句防止 SQL 注入(示例中用 ? 占位符示意)
$result = $conn->executeSQL($sql, [$roleId]); // 假设 executeSQL 支持参数绑定
$tasks = [];
foreach ($result as $row) {
$tasks[] = $row['task']; // 提取所有 task 值
}
// 对当前员工的所有任务去重,并强制重置索引(可选)
$array[24] = array_values(array_unique($tasks));
}
return $array;
}
注意:原始代码中,若使用 `$value['employee']` 这类变量,可能在外层循环后被覆盖而不可用。更安全的做法是像示例中一样,使用固定键(如 24)或从 `$result` 中安全提取员工 ID。同时,务必使用参数化查询替代字符串拼接,这是杜绝 SQL 注入风险的关键。
如果任务数量不多,或希望在构建数组时即时跳过重复项,条件判断的方式更为灵活。其思路是:在将每个任务加入数组前,先检查是否已存在。
立即学习“PHP免费学习笔记(深入)”;
function Job($conn) {
$array = [];
foreach (array_unique($_SESSION['ROLES']) as $roleId) {
$sql = "SELECT employee, task FROM table WHERE id = ? AND employee = 24";
$result = $conn->executeSQL($sql, [$roleId]);
foreach ($result as $row) {
$empId = $row['employee'];
$task = $row['task'];
// 仅当该任务尚未存在于当前员工数组中时才添加
if (!in_array($task, $array[$empId] [])) {
$array[$empId][] = $task;
}
}
}
return $array;
}
性能提示:`in_array()` 函数在大数据集上进行线性搜索,时间复杂度为 O(n)。若单个员工的任务条数超过上百条,性能开销会较明显,此时建议优先选用方案一。此外,代码中 `$array[$empId] []` 的写法很巧妙,它提供了空数组作为默认值,可有效避免因索引未定义而引发的警告。
假设处理前的输入数据如下(包含重复项):
[24] => ['21', '22', '21', '22']
那么,经上述任一方法去重后,输出结果将变得干净、简洁:
[24] => ['21', '22'] // 索引自动重排为 0,1
总之,根据具体场景选择以上任一方式,都能帮助您稳健、安全地获得无重复任务的结构化数组,使后续数据处理更加顺畅。
侠游戏发布此文仅为了传递信息,不代表侠游戏网站认同其观点或证实其描述