去重的:
公司主營業(yè)務(wù):成都網(wǎng)站建設(shè)、成都做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出山丹免費(fèi)做網(wǎng)站回饋大家。
/**
*?二維數(shù)組按照指定鍵值去重
*?@param?$arr?需要去重的二維數(shù)組
*?@param?$key?需要去重所根據(jù)的索引
*?@return?mixed
*/
function?assoc_unique($arr,?$key)
{
$tmp_arr?=?array();
foreach($arr?as?$k?=?$v)?{
if(in_array($v[$key],$tmp_arr))?{??//搜索$v[$key]是否在$tmp_arr數(shù)組中存在,若存在返回true
unset($arr[$k]);
}?else?{
$tmp_arr[]?=?$v[$key];
}
}
sort($arr);?//sort函數(shù)對數(shù)組進(jìn)行排序
return?$arr;
}
?php
function array_unique_fb($array2D){
foreach ($array2D as $v){
$v = join(",",$v); //降維,也可以用implode,將一維數(shù)組轉(zhuǎn)換為用逗號連接的字符串
$temp[] = $v;
}
$temp = array_unique($temp); //去掉重復(fù)的字符串,也就是重復(fù)的一維數(shù)組
foreach ($temp as $k = $v){
$temp[$k] = explode(",",$v); //再將拆開的數(shù)組重新組裝
}
return $temp;
}
$aa = array(
array('id' = 123, 'name' = '張三'),
array('id' = 123, 'name' = '李四'),
array('id' = 124, 'name' = '王五'),
array('id' = 123, 'name' = '李四'),
array('id' = 126, 'name' = '趙六')
);
$bb=array_unique_fb($aa);
print_r($bb)
?
顯示結(jié)果:Array ( [0] = Array ( [0] = 123 [1] = 張三 ) [1] = Array ( [0] = 123 [1] = 李四 ) [2] = Array ( [0] = 124 [1] = 王五 ) [4] = Array ( [0] = 126 [1] = 趙六 ) )
百度一下就找到答案了
可以寫個方法,查詢所有數(shù)據(jù),然后遍歷數(shù)組,查詢的時候分組查詢(按照某一字段即可),如果該組數(shù)據(jù)量1,則刪除,只保留一條即可。SQL語句會寫就可以
$arr = array(1,2,4,2,0,9,8,5);//定義一個數(shù)組。
$arr1 = $arr; //定義另一個數(shù)組和上一個數(shù)組一樣。
//循環(huán)第一個數(shù)組讓后循環(huán)第二個數(shù)組 用第一個數(shù)組的每個值和第二個數(shù)組比較如果相同就刪除,最后輸出第二個數(shù)組就行了。
for($i = 0;$icount($arr);$i++){
for($j=$i+1;$jcount($arr);$j++){
if($arr[$i] == $arr[$j])
unset($arr1[$i]);
}
}
echo'pre';
print_r($arr1);
第二 如果允許使用array_uniqe()函數(shù)的話,直接array_uniqe(直接寫數(shù)組名就ok)。
在PHP中可以使用內(nèi)置函數(shù)array_unique()來直接刪除重復(fù)元素,也可以使用array_flip()函數(shù)來間接刪除重復(fù)元素。
1.array_unique()函數(shù)
array_unique()函數(shù)可以移除數(shù)組中的重復(fù)的值,并返回結(jié)果數(shù)組;當(dāng)幾個數(shù)組元素的值相等時,只保留第一個元素,其他的元素被刪除。
代碼示例:
?php$result1 = array("a" = "green", "red", "b" = "green", "blue",
"red");var_dump($result1);$result2 = array_unique($result1);var_dump($result2);?
2.array_flip()函數(shù)
array_flip()是反轉(zhuǎn)數(shù)組鍵和值的函數(shù),它有個特性就是如果數(shù)組中有二個值是一樣的,那么反轉(zhuǎn)后會保留最后一個鍵和值,利用這個特性我們用他來間接的實(shí)現(xiàn)數(shù)組的去重。
代碼示例:
?phpheader("content-type:text/html;
charset=utf-8");$a = array(1, 5, 2, 5, 1, 3, 2, 4, 5);// 輸出原始數(shù)組echo "原始數(shù)組
:";var_dump($a);// 。
通過使用翻轉(zhuǎn)鍵和值移除重復(fù)值$a = array_flip($a);
// 通過再次翻轉(zhuǎn)鍵和值來恢復(fù)數(shù)組元素$a = array_flip($a);// 重新排序數(shù)組鍵$a = array_values($a);// 輸出更新后的數(shù)組echo "更新數(shù)組 :";var_dump($a);?
擴(kuò)展資料:
在 PHP 中創(chuàng)建數(shù)組:
在 PHP 中,?array()?函數(shù)用于創(chuàng)建數(shù)組:
array();
在 PHP 中,有三種數(shù)組類型:
索引數(shù)組?- 帶有數(shù)字索引的數(shù)組。
關(guān)聯(lián)數(shù)組?- 帶有指定鍵的數(shù)組。
多維數(shù)組?- 包含一個或多個數(shù)組的數(shù)組。
1、PHP 索引數(shù)組
有兩種創(chuàng)建索引數(shù)組的方法:
索引是自動分配的(索引從 0 開始):
$cars=array("porsche","BMW","Volvo");
或者也可以手動分配索引:
$cars[0]="porsche";
2、遍歷索引數(shù)組:
如需遍歷并輸出索引數(shù)組的所有值,可以使用 for 循環(huán),就像這樣:
實(shí)例:
?php
$cars=array("porsche","BMW","Volvo");
$arrlength=count($cars);
for($x=0;$x$arrlength;$x++) {
echo $cars[$x];
echo "br";
}
?
3、多維數(shù)組:
將在 PHP 高級教程出現(xiàn)多維數(shù)組。
參考資料來源:百度百科-PHP
方法一:
//二維數(shù)組去掉重復(fù)值
function?array_unique_fb($array2D){
foreach?($array2D?as?$v){
$v=join(',',$v);??//降維,也可以用implode,將一維數(shù)組轉(zhuǎn)換為用逗號連接的字符串
$temp[]=$v;
}
$temp=array_unique($temp);????//去掉重復(fù)的字符串,也就是重復(fù)的一維數(shù)組
foreach?($temp?as?$k?=?$v){
$temp[$k]=explode(',',$v);???//再將拆開的數(shù)組重新組裝
}
return?$temp;
}
方法二:
//二維數(shù)組去掉重復(fù)值,并保留鍵值
function?array_unique_fb($array2D){
foreach?($array2D?as?$k=$v){
$v=join(',',$v);??//降維,也可以用implode,將一維數(shù)組轉(zhuǎn)換為用逗號連接的字符串
$temp[$k]=$v;
}
$temp=array_unique($temp);?//去掉重復(fù)的字符串,也就是重復(fù)的一維數(shù)組????
foreach?($temp?as?$k?=?$v){
$array=explode(',',$v);?//再將拆開的數(shù)組重新組裝
//下面的索引根據(jù)自己的情況進(jìn)行修改即可
$temp2[$k]['id']?=$array[0];
$temp2[$k]['title']?=$array[1];
$temp2[$k]['keywords']?=$array[2];
$temp2[$k]['content']?=$array[3];
}
return?$temp2;
}
默認(rèn)的 fetch、fetchAll 函數(shù)是用 ?PDO::FETCH_BOTH 為設(shè)置來返回結(jié)果集的,在這種形式下,會“返回一個索引為結(jié)果集列名和以0開始的列號的數(shù)組”,就是如你上面截圖的那樣:索引與鍵名都有。
fetchAll 的語法如下:
array?PDOStatement::fetchAll?([?int?$fetch_style?[,?mixed?$fetch_argument?[,?array?$ctor_args?=?array()?]]]?)
你可以試試將第1個可選參數(shù) $fecth_style,設(shè)置為 PDO::FETCH_ASSOC。