[英]Return unique values from a column with multiple values per field
我有一个数据库表,其中有一列,其中每个字段中存储有多个字符串,并用;隔开;
我需要获取该列中所有唯一值的列表。 我知道必须有一种更简单的方法来执行此操作,但是我在任何地方都找不到答案。 到目前为止,这是我正在做的事情:
$result = mysql_query("SELECT DISTINCT column FROM modx_scripture_table WHERE column!=''", $con);
$filter_all = array();
while($row = mysql_fetch_array($result))
{
$filter_all[] = $row;
}
function array_flatten($array) {
if (!is_array($array)) {
return FALSE;
}
$result = array();
foreach ($array as $key => $value) {
if (is_array($value)) {
$result = array_merge($result, array_flatten($value));
}
else {
$result[$key] = $value;
}
}
return $result;
}
$filter_flat = array_flatten($filter_all);
function array_explode($array) {
$result = array();
foreach ($array as $key => $value) {
$result[$key] = explode(';',$value);
}
return $result;
}
$filter_sploded = array_explode($filter_flat);
$filter_full = array_flatten($filter_sploded);
$filter_final = array_unique($filter_full);
print_r($filter_final);
除了array_unique之外,其他所有东西似乎都在工作。 我仍然在$ filter_final中得到重复的字符串。 我究竟做错了什么?
array_unique()
字符串后,使用array_unique()
查找数组中的唯一值。
例:
$arr=array('1','2','3','4','5','3','1');
print_r(array_unique($arr));
输出:
Array
(
[0] => 1
[1] => 2
[2] => 3
[3] => 4
[4] => 5
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.