你好,這是我解決你這個(gè)問題的思路,希望能幫到你:比如你是根據(jù)a字段設(shè)置唯一,在每次插入之前就使用下一條需要插入的值去數(shù)據(jù)表里面查詢,如果查詢到了就跳出當(dāng)前循環(huán),下次循環(huán)繼續(xù)(continue),希望能幫到你!
創(chuàng)新互聯(lián)是一家專業(yè)提供嘉祥企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、成都h5網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為嘉祥眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。
我覺得問題:
1,每次用$rs ,清空一下.
2.這句話$row=mysql_fetch_row($result)在while循環(huán)里面感覺重復(fù)了.
一個(gè)就可以了,去掉下面那個(gè).
$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(直接寫數(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)幾個(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)后會保留最后一個(gè)鍵和值,利用這個(gè)特性我們用他來間接的實(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ù)組?- 包含一個(gè)或多個(gè)數(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
先用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);
?
兩種方法
第一種是修改查詢語句,在查詢語句中去除重復(fù)項(xiàng)
select distinct 列名 from 表明????只適用于查詢單列數(shù)據(jù),網(wǎng)上的查詢多列的方法試過一些,都報(bào)錯(cuò)
第二種方法是把查到的數(shù)據(jù)先讀進(jìn)一個(gè)數(shù)組,然后使用array_unique()函數(shù)去除重復(fù)項(xiàng),再使用foreach遍歷數(shù)組來拼湊下拉框選項(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)
}
希望能幫到你
?php
$array?=?array(
array(
'id'?=?19,
'title'?=?'總統(tǒng)套房'
),
array(
'id'?=?20,
'title'?=?'豪華套房'
),
array(
'id'?=?21,
'title'?=?'豪華套房'
),
array(
'id'?=?22,
'title'?=?'總統(tǒng)套房'
),
);
foreach?($array?as?$key?=?$value)?{
foreach?($value?as?$k?=?$v)?{
if?($k?==?'title')?{
$new_arr[]?=?$v;
}
}
}
$arr?=?array_unique($new_arr);
echo?implode(',',?$arr);
?
望采納 Thx
網(wǎng)站題目:php中循環(huán)去重復(fù)數(shù)據(jù) for循環(huán)去除重復(fù)的數(shù)據(jù)
網(wǎng)站路徑:http://aaarwkj.com/article24/docpsje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、網(wǎng)站排名、做網(wǎng)站、網(wǎng)站收錄、網(wǎng)站內(nèi)鏈、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)