繁体   English   中英

mysql / php-在while语句中合并来自mysql输出的多个数组

[英]mysql/php - merge multiple arrays from mysql output in while statement

我需要从我拥有的mysql数据库中合并许多数组。 数组的数量可以变化。 我正在将数据序列化到数据库中,并在输出时反序列化。 我感到困惑的地方是尝试使用array_merge但不确定如何正确地将数据放入其中。

例如我有

$sql_get_votes_data = "SELECT * FROM algo_users WHERE data LIKE '%$movie_id%'";
$result_get_votes_data = mysql_query($sql_get_votes_data);
$final_array = array();
while($row_get_votes_data = mysql_fetch_array($result_get_votes_data)) {
    $final_array[] = unserialize($row_get_votes_data['data']);
}

最终,我需要能够进行这样的独特合并。

array_unique(array_merge($final_array1,$final_array2), SORT_REGULAR);

但是由于我必须将每个数组放入一个单独的变量中才能传递给array_merge所以我不确定如何从mysql调用中做到这一点。

任何帮助都是极好的。

为什么不在循环中合并每个新数组?

$mergedArray=array();
while($row_get_votes_data = mysql_fetch_array($result_get_votes_data)) {
    $final_array = unserialize($row_get_votes_data['data']);
    $mergedArray=array_merge($mergedArray,$final_array);
}
array_unique($mergedArray, SORT_REGULAR);

或者,如果您需要跟踪各个阵列:

$mergedArray=array();
$i=0;
while($row_get_votes_data = mysql_fetch_array($result_get_votes_data)) {
    $final_array[$i] = unserialize($row_get_votes_data['data']);
    $mergedArray=array_merge($mergedArray,$final_array[$i]);
    $i++
}
array_unique($mergedArray, SORT_REGULAR);

编辑:我首先了解到您只想将所有数组合并到单个数组。 根据我现在的理解,上面编辑的答案现在也删除了重复的条目。

您可以例如使用call_user_func_array

<?php
$myarrs = array();

$result = call_user_func_array( 'array_merge', $myarrs); var_dump($result);

$myarrs[] = array(1,2,3);
$result = call_user_func_array( 'array_merge', $myarrs); var_dump($result);

$myarrs[] = array(4,5,6);
$result = call_user_func_array( 'array_merge', $myarrs); var_dump($result);

$myarrs[] = array(7,8,9);
$result = call_user_func_array( 'array_merge', $myarrs); var_dump($result);

但是也许重组数据库而不是将序列化的数组而是单个字段放入表中是更可行的,数据库可以进行排序/过滤/合并。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM