前言
有时候在数据库进行join关联查询数据的时候会查询出一些重复的数据需要进行手动去重操作,避免返回到列表中出现重复的数据。
/**
* 1.删除二维数组中相同项的数据,一般用于数据库查询结果中相同记录的去重操作
* 2.重置一下二维数组的索引
* @param array $_2d_array 二维数组,类似:
* $tmpArr = array(
* array('id' => 1, 'value' => '15046f5de5bb708e'),
* array('id' => 1, 'value' => '15046f5de5bb708e'),
* );
* @param string $unique_key 表示上述数组的 "id" 键,或者 "value" 键
* @return mixed
*/
function unique_2d_array_by_key($_2d_array, $unique_key)
{
$tmp_key[] = array();
foreach ($_2d_array as $key => &$item) {
if (is_array($item) && isset($item[$unique_key])) {
if (in_array($item[$unique_key], $tmp_key)) {
unset($_2d_array[$key]);
} else {
$tmp_key[] = $item[$unique_key];
}
}
}
//重置一下二维数组的索引
return array_slice($_2d_array, 0, count($_2d_array), false);
}