PHP explode()返回数组中的数组

时间:2017-10-20 12:44:28

标签: php sql arrays function explode

我有以下功能:

function GetTagsOfUser(){
    require "include/connect.php";
    $sql = "SELECT * FROM users WHERE User='Chona'";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
        while ($row = $result->fetch_assoc()){
            $tagsOfUser[] = explode(';', $row['Tags']);
        }
        return $tagsOfUser;
    }
}

调用它并打印时

print_r($Recomend->GetTagsOfUser());

我得到以下内容:

array(1) { [0]=> array(4) { [0]=> string(6) "Paises" [1]=> string(7) "Francia" [2]=> string(19) "Revolucion Francesa" [3]=> string(3) "ONU" } }

好像我的数组里面有一个包含字符串的数组,我想要一个数组,请帮忙。

2 个答案:

答案 0 :(得分:1)

变量$ tagsOfUser []是一个数组:

$tagsOfUser[] = explode(';', $row['Tags']);

爆炸返回一个数组,结果就是你正在做的事情。

删除" []"从变量名称,您的问题将得到解决。

答案 1 :(得分:1)

您将结果数组从explode设置为另一个数组($tagsOfUser):

$tagsOfUser[] = explode(';', $row['Tags']);

您可以使用array_merge来解决此问题:

$tagsOfUser = array_merge($tagsOfUser, explode(';', $row['Tags']));
function GetTagsOfUser() {
    require "include/connect.php";

    $sql = "SELECT * FROM users WHERE User='Chona'";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
        $tagsOfUser= [];

        while ($row = $result->fetch_assoc()){
            $tagsOfUser = array_merge($tagsOfUser, explode(';', $row['Tags']));
        }

        return $tagsOfUser;
    }
}

您只需要/需要一行(针对特定用户)?

在这种情况下,您不需要while循环或$tagsOfUser变量:

function GetTagsOfUser() {
    require "include/connect.php";

    $sql = "SELECT TOP 1 * FROM users WHERE User = 'Chona'";
    $result = $conn->query($sql);

    if ($result->num_rows == 1) {
        $row = $result->fetch_assoc();
        return explode(';', $row['Tags']);
    } else {
        return [];
    }
}