重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
php页面上放一个删除数据库重复数据的功能按钮,就是使用PHP操作数据库删除重复数据的SQL语句,然后重新查询绑定输出。
创新互联建站是一家企业级云计算解决方案提供商,超15年IDC数据中心运营经验。主营GPU显卡服务器,站群服务器,西部信息服务器托管,海外高防服务器,成都机柜租用,动态拨号VPS,海外云手机,海外云服务器,海外服务器租用托管等。
如果是PHP操作数据库不明白的话,就找PHP操作数据库这篇内容来看。
如果是用SQL语句来删除数据库重复数据不明白的话就找SQL删除重复数据这方面的内容。
如果你要具体的实现代码,不好意思,帮不了你,这需要你自己找,自己实现。这是程序员必备的技能。
array_unique() 函数移除数组中的重复的值,并返回结果数组。
当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除。
返回的数组中键名不变。
array_unique() 先将值作为字符串排序,然后对每个值只保留第一个遇到的键名,接着忽略所有后面的键名。这并不意味着在未排序的 array 中同一个值的第一个出现的键名会被保留。
1.首先,题主应该选一个相似度的计算维度,比如content字段,type字段等;
2.其次,题主考虑一下各个字段的权重,比如type字段必须相同,则让type字段使用typeWeight(例如赋值0.8)作为乘积的因子,而content字段本身是比较长的,所以需要计算出一个hash值,比如使用特定算法计算出一个hash值,然后把这个hash值按照16进制计算得到10进制数,再给一个权重contentWeight(例如0.2),另外再选取一个字段,比如description描述字段,再给一个权重descriptionWeight...
3.最后得到一个当前插入到表中的记录综合hash,typeWeight(contentHashcontentWeight+descriptionHash*descriptionWeight +...),可能会涉及到大整数计算,不过PHP有BCMATH扩展可以使用,最终得到一个数值的综合hash值,保存到数据库的一个字段中,这个东西就可以理解为本条记录的特征值。
这样的话,是有些麻烦啦,你得一项一项去比较才行,你先比较从2到9这几项的类型,然后再去比较每一项当中的数目,然后再比较每一项当中每一项的值是不是相同才行,比较相同要用“===”,而不是“==”,这一点得注意下;
先将所有数据放到一个数组里
$arr_new_str =Array();//放字符串的数组
$arr_new_obj = Array();//放对象的数组
foreach( $arr_old as $arr_in ){
foreach( $arr_in as $value){
//双重遍历,开始 将字符串和对象分开
if( $value instanceof stdClass )
{ //所有对象
$arr_new_obj[] =$value;
}else {//所有字符串
$arr_new_str[]=$value;
}
}
}
//array_unique()函数,我不清楚能不能排除对象,所以我又分了一次
$arr_new= array_unique( $arr_new_str );
//验证对象
$count = count( $arr_new_obj);
for( $i=0;$i$count;$i++){
//得到对象数组的第一个值,
for($j=$i+1;$j$count;$j++){
//将第一个对象和其他值比较,
if( $arr_new_obj[ i ] == $arr_new_obj[ j ] ){
//相等,就将第一个删除;依次类推
unset( $arr_new_obj[ i ] );
}
}
}
//最后得到的就是没有相同对象的新数组
//和并两个数组;
$array_new = array_merge( $arr_new ,$arr_new_obj );
//array_merge() 函数把两个或多个数组合并为一个数组。
//如果键名有重复,该键的键值为最后一个键名对应的值(后面的覆盖前面的)。如果数组是数
//字索引的,则键名会以连续方式重新索引。
这个题,我认为 难在如何判断两个对象是否相等,我也是,百度了一下,才知道的,请楼主也学习一下;
我的方法比较长,我看一楼 用到的 递归,水准比我高多了,学习了
先用explode()函数分解成数组,然后用array_unique() 函数给数组去重复,然后用implode()合并成字符串
?php
$str='1|2|1|5|4|2';
$a=explode('|',$str);
$b=array_unique($a);
$c=implode('|',$b);
var_dump($c);
?