我有以下功能:
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" } }
好像我的数组里面有一个包含字符串的数组,我想要一个数组,请帮忙。
答案 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 [];
}
}