>  기사  >  백엔드 개발  >  关于避免插入重复数据并统计重复数据的数量的有关问题

关于避免插入重复数据并统计重复数据的数量的有关问题

WBOY
WBOY원래의
2016-06-13 13:21:28849검색

关于避免插入重复数据并统计重复数据的数量的问题
有一组数据需要插入数据库,比如从EXCEL导入一组数据到MYSQL数据库,如何避免重复插入,这里所指的重复并不是指某一个字段的重复,而是多个字段组合的重复,比如:
id name content  
1 张三 吃饭  
2 李四 吃饭
3 张三 喝水

如上,如果name 和 content字段的值都重复才算重复,比如再插入一条"张三,吃饭"就提示重复并统计出重复的数量和已插入数据的数量,求PHP语句。

------解决方案--------------------

PHP code
$excelData = array(
    array('张三', '吃饭'),
    array('李四', '吃饭'),
    array('张三', '喝水'),
    array('李四', '吃饭'),// 重复
    array('张三', '喝水') // 重复
);

$mark = array(); // 用来当作唯一标识
foreach ($excelData as $key => $arr) {
    $md5Mark = md5($arr[0] . $arr[1]);
    if (isset($mark[$md5Mark])) {
        unset($excelData[$key]);
    } else {
        $mark[$md5Mark] = 1;
    }
}

// 此时你就可以操作$excelData而不用判断了,当然了你也可以直接在else中进行sql语句的组合或者数据库写入操作
p($excelData);
/*
输出:
Array
(
    [0] => Array
        (
            [0] => 张三
            [1] => 吃饭
        )

    [1] => Array
        (
            [0] => 李四
            [1] => 吃饭
        )

    [2] => Array
        (
            [0] => 张三
            [1] => 喝水
        )

)
*/ <div class="clear">
                 
              
              
        
            </div>
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.