可以寫(xiě)個(gè)方法,查詢所有數(shù)據(jù),然后遍歷數(shù)組,查詢的時(shí)候分組查詢(按照某一字段即可),如果該組數(shù)據(jù)量1,則刪除,只保留一條即可。SQL語(yǔ)句會(huì)寫(xiě)就可以
成都創(chuàng)新互聯(lián)是一家企業(yè)級(jí)云計(jì)算解決方案提供商,超15年IDC數(shù)據(jù)中心運(yùn)營(yíng)經(jīng)驗(yàn)。主營(yíng)GPU顯卡服務(wù)器,站群服務(wù)器,雅安服務(wù)器托管,海外高防服務(wù)器,大帶寬服務(wù)器,動(dòng)態(tài)撥號(hào)VPS,海外云手機(jī),海外云服務(wù)器,海外服務(wù)器租用托管等。
array_unique
()
函數(shù)用于移除數(shù)組中重復(fù)的值。如果兩個(gè)或更多個(gè)數(shù)組值相同,只保留第一個(gè)值,其他的值被移除。
注意:被保留的數(shù)組將保持第一個(gè)數(shù)組項(xiàng)的鍵名類型
$arr = array(1,2,4,2,0,9,8,5);//定義一個(gè)數(shù)組。
$arr1 = $arr; //定義另一個(gè)數(shù)組和上一個(gè)數(shù)組一樣。
//循環(huán)第一個(gè)數(shù)組讓后循環(huán)第二個(gè)數(shù)組 用第一個(gè)數(shù)組的每個(gè)值和第二個(gè)數(shù)組比較如果相同就刪除,最后輸出第二個(gè)數(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(直接寫(xiě)數(shù)組名就ok)。
在PHP中可以使用內(nèi)置函數(shù)array_unique()來(lái)直接刪除重復(fù)元素,也可以使用array_flip()函數(shù)來(lái)間接刪除重復(fù)元素。
1.array_unique()函數(shù)
array_unique()函數(shù)可以移除數(shù)組中的重復(fù)的值,并返回結(jié)果數(shù)組;當(dāng)幾個(gè)數(shù)組元素的值相等時(shí),只保留第一個(gè)元素,其他的元素被刪除。
代碼示例:
?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ù),它有個(gè)特性就是如果數(shù)組中有二個(gè)值是一樣的,那么反轉(zhuǎn)后會(huì)保留最后一個(gè)鍵和值,利用這個(gè)特性我們用他來(lái)間接的實(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);// 。
通過(guò)使用翻轉(zhuǎn)鍵和值移除重復(fù)值$a = array_flip($a);
// 通過(guò)再次翻轉(zhuǎn)鍵和值來(lái)恢復(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ù)組?- 包含一個(gè)或多個(gè)數(shù)組的數(shù)組。
1、PHP 索引數(shù)組
有兩種創(chuàng)建索引數(shù)組的方法:
索引是自動(dòng)分配的(索引從 0 開(kāi)始):
$cars=array("porsche","BMW","Volvo");
或者也可以手動(dòng)分配索引:
$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 高級(jí)教程出現(xiàn)多維數(shù)組。
參考資料來(lái)源:百度百科-PHP
一、這個(gè)沒(méi)有被合并,只是取的后面這個(gè)鍵名的值,
二、$input=array("11"="aaaa","22"="bbbb","33"="cccc","11"="aaada","44"="cccc1","55"="cccc");
$result
=
array_unique
($input);
print_r($result);
輸出的結(jié)果:Array
(
[11]
=
aaada
[22]
=
bbbb
[33]
=
cccc
[44]
=
cccc1
)
鍵名33
和
55
的值完全一樣的時(shí)候,后者會(huì)被干掉
如果你要的是鍵名和值完全一致的時(shí)候才刪除一個(gè)的話,似乎不能,因?yàn)殒I名是不允許重復(fù)的
聽(tīng)你的情況似乎數(shù)據(jù)量很大,建議你使用
array_flip()函數(shù)
【php中,刪除數(shù)組中重復(fù)元素有一個(gè)可用的函數(shù),那就是array_unique(),
但是它并不是一個(gè)最高效的方法,使用array_flip()函數(shù)將比array_uniqure()在速度上高出五倍左右。】
例子:$input=array("11"="aaaa","22"="bbbb","33"="cccc","11"="aaada","44"="cccc1","55"="cccc");
$arr1
=
array_flip(array_flip($input));
print_r($arr1);
輸出的結(jié)果:Array
(
[11]
=
aaada
[22]
=
bbbb
[55]
=
cccc
[44]
=
cccc1
)
兩種方法
第一種是修改查詢語(yǔ)句,在查詢語(yǔ)句中去除重復(fù)項(xiàng)
select distinct 列名 from 表明????只適用于查詢單列數(shù)據(jù),網(wǎng)上的查詢多列的方法試過(guò)一些,都報(bào)錯(cuò)
第二種方法是把查到的數(shù)據(jù)先讀進(jìn)一個(gè)數(shù)組,然后使用array_unique()函數(shù)去除重復(fù)項(xiàng),再使用foreach遍歷數(shù)組來(lái)拼湊下拉框選項(xiàng)
$arr=[];
while($row?=?mysql_fetch_array($result))?{
array_push($arr,$row[Keyword]);//讀進(jìn)數(shù)組
}
$arr=array_unique($arr);//去除重復(fù)項(xiàng)
foreach?($arr?as?$key?=?$val)?{
echo?"option?value='$val'$val/option";//循環(huán),拼湊下拉框選項(xiàng)
}
希望能幫到你
先用explode()函數(shù)分解成數(shù)組,然后用array_unique() 函數(shù)給數(shù)組去重復(fù),然后用implode()合并成字符串
?php
$str='1|2|1|5|4|2';
$a=explode('|',$str);
$b=array_unique($a);
$c=implode('|',$b);
var_dump($c);
?
文章標(biāo)題:php如何去除重復(fù)數(shù)據(jù) php如何去除重復(fù)數(shù)據(jù)中的數(shù)據(jù)
當(dāng)前路徑:http://aaarwkj.com/article16/dochodg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、定制網(wǎng)站、網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、云服務(wù)器、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)