如何删除重复php array_unique无法正常工作

时间:2017-01-18 00:24:14

标签: php mysql duplicates array-unique

我尝试使用array_unique();但不工作这是我的代码请帮我解决我做错了什么?我希望显示没有重复的所有标签

ID | TAGS
1 | rock, punk, jazz
2 | pop, rock, classic
3 | jazz, blues, rock
4 | rock, rap, metal

$wynik = mysql_query("SELECT * FROM nabk_t_item_tags") or die('Błąd zapytania');
if (mysql_num_rows($wynik) > 0) {
    while ($r = mysql_fetch_assoc($wynik)) {
        $input = $r['tags'];
        $fields = explode(',', $input);
        $fields2 = array_unique($fields);
        foreach ($fields2 as $field) {
            echo '"' . $field . '",';
        }
    }
}

2 个答案:

答案 0 :(得分:1)

您必须将查询中的所有标记放在一个数组中。因此,使用您现有的代码:

// $fields2 = array_unique($fields);
$fields2 = array_merge($fields2, $fields);

然后在while循环之后,$fields2将拥有所有标记,您可以使用array_unique该数组。所以,添加这些行并查看结果:

    } // end while
    $unique_tags = array_unique($fields2);
    var_dump($unique_tags);
} // end if

答案 1 :(得分:0)

试试这段代码。

if (mysql_num_rows($wynik) > 0) {
    $used=array();
    while ($r = mysql_fetch_assoc($wynik)) {
        $input = $r['tags'];
        $fields = explode(',', $input);
        foreach($fields as $tg){
            if(!isset($used[$tg])){
                echo '"' . $tg . '",';
                $used[$tg]=" ";
            }   
        }
    }
    unset($used);
}