189 8069 5689

数据库去除重复数据php,怎么删除数据库重复数据

php怎么删除数据库中重复的数据,只剩一个

可以写个方法,查询所有数据,然后遍历数组,查询的时候分组查询(按照某一字段即可),如果该组数据量1,则删除,只保留一条即可。SQL语句会写就可以

创新互联公司专注于企业全网营销推广、网站重做改版、峨山县网站定制设计、自适应品牌网站建设、html5商城系统网站开发、集团公司官网建设、成都外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为峨山县等各大城市提供网站开发制作服务。

php 删除数组重复的值

$arr = array(1,2,4,2,0,9,8,5);//定义一个数组。

$arr1 = $arr; //定义另一个数组和上一个数组一样。

//循环第一个数组让后循环第二个数组 用第一个数组的每个值和第二个数组比较如果相同就删除,最后输出第二个数组就行了。

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()函数的话,直接array_uniqe(直接写数组名就ok)。

在PHP中可以使用内置函数array_unique()来直接删除重复元素,也可以使用array_flip()函数来间接删除重复元素。

1.array_unique()函数

array_unique()函数可以移除数组中的重复的值,并返回结果数组;当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除。

代码示例:

?php$result1 = array("a" = "green", "red", "b" = "green", "blue",

"red");var_dump($result1);$result2 = array_unique($result1);var_dump($result2);?

2.array_flip()函数

array_flip()是反转数组键和值的函数,它有个特性就是如果数组中有二个值是一样的,那么反转后会保留最后一个键和值,利用这个特性我们用他来间接的实现数组的去重。

代码示例:

?phpheader("content-type:text/html;

charset=utf-8");$a = array(1, 5, 2, 5, 1, 3, 2, 4, 5);// 输出原始数组echo "原始数组

:";var_dump($a);// 。

通过使用翻转键和值移除重复值$a = array_flip($a);

// 通过再次翻转键和值来恢复数组元素$a = array_flip($a);// 重新排序数组键$a = array_values($a);// 输出更新后的数组echo "更新数组 :";var_dump($a);?

扩展资料:

在 PHP 中创建数组:

在 PHP 中, array() 函数用于创建数组:

array();

在 PHP 中,有三种数组类型:

索引数组 - 带有数字索引的数组。

关联数组 - 带有指定键的数组。

多维数组 - 包含一个或多个数组的数组。

1、PHP 索引数组

有两种创建索引数组的方法:

索引是自动分配的(索引从 0 开始):

$cars=array("porsche","BMW","Volvo");

或者也可以手动分配索引:

$cars[0]="porsche";

2、遍历索引数组:

如需遍历并输出索引数组的所有值,可以使用 for 循环,就像这样:

实例:

?php

$cars=array("porsche","BMW","Volvo");

$arrlength=count($cars);

for($x=0;$x$arrlength;$x++) {

echo $cars[$x];

echo "br";

}

?

3、多维数组:

将在 PHP 高级教程出现多维数组。

参考资料来源:百度百科-PHP

php 去掉完全相同的重复数组

一、这个没有被合并,只是取的后面这个键名的值,

二、$input=array("11"="aaaa","22"="bbbb","33"="cccc","11"="aaada","44"="cccc1","55"="cccc");

$result

=

array_unique

($input);

print_r($result);

输出的结果:Array

(

[11]

=

aaada

[22]

=

bbbb

[33]

=

cccc

[44]

=

cccc1

)

键名33

55

的值完全一样的时候,后者会被干掉

如果你要的是键名和值完全一致的时候才删除一个的话,似乎不能,因为键名是不允许重复的

听你的情况似乎数据量很大,建议你使用

array_flip()函数

【php中,删除数组中重复元素有一个可用的函数,那就是array_unique(),

但是它并不是一个最高效的方法,使用array_flip()函数将比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);

输出的结果:Array

(

[11]

=

aaada

[22]

=

bbbb

[55]

=

cccc

[44]

=

cccc1

)

如何用原生php在数据库里删除重复的数据(筛选重复的,然后删除,留下一条就可以 )

delete YourTable

where [id] not in (

select max([id]) from YourTable

group by (name + value))


当前文章:数据库去除重复数据php,怎么删除数据库重复数据
文章链接:http://cdxtjz.cn/article/dsihdop.html

其他资讯