首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示ManyToMany查询的所有结果

显示ManyToMany查询的所有结果
EN

Stack Overflow用户
提问于 2014-08-04 21:50:47
回答 1查看 29关注 0票数 0

我的脑子里已经完全空白了,但是我现在有很多的关系设置,我正在努力弄清楚如何将数据打印回php端。我知道我可以调用以下命令在phpmyadmin中显示结果:

代码语言:javascript
复制
SELECT skills. * 
FROM `skills_matches` skills_matches 
LEFT JOIN `skills` ON skills.id = skills_matches.skillid 
LEFT JOIN `users` ON users.id = skills_matches.userid 
WHERE skills_matches.userid =70 LIMIT 0 , 30

然后,我有以下函数来调用该查询:

代码语言:javascript
复制
function fetchAllUserSkills($id)
{
    global $mysqli,$db_table_prefix; 
    $stmt = $mysqli->prepare('SELECT skills . * '
        . ' FROM `skills_matches` skills_matches'
        . ' LEFT JOIN `skills` ON skills.id = skills_matches.skillid'
        . ' LEFT JOIN `users` ON users.id = skills_matches.userid'
        . ' WHERE skills_matches.userid = ?'
        . ' LIMIT 0 , 30');
        $stmt->bind_param("s", $id);

    $stmt->execute();
    $stmt->bind_result($id, $skills);
    while ($stmt->fetch()){
        $row = array('id' => $id, 'skills' => $skills);
    }
    $stmt->close();
    return ($row);
}

但是,当我尝试下列语句时,结果显示为空白:

代码语言:javascript
复制
$skillDetails = fetchAllUserSkills(70);
echo $skillDetails['skill'];
echo $skillDetails; 

我在$skillDetails上做了一个$skillDetails,得到了以下内容:

代码语言:javascript
复制
array(2) { ["id"]=> int(15) ["skills"]=> string(5) "sales" }

所以问题是:像我在phpmyadmin中所做的那样,为了在php中显示来自该查询的所有结果,我遗漏了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-04 21:53:02

您每次都要覆盖$row:

代码语言:javascript
复制
$row = array('id' => $id, 'skills' => $skills);

应该是

代码语言:javascript
复制
$row[] = array('id' => $id, 'skills' => $skills);

然后,为了显示,您将遍历返回的数据:

代码语言:javascript
复制
$skillDetails = fetchAllUserSkills(70);
foreach($skillDetails as $row) {
    echo $row['skills'];
} 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25128166

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档