php - 如何为两个准备好的语句获取数据? (MySQLi)

标签 php html mysql css mysqli

如何使用 MySQLi 获取两个准备好的语句的结果?

我正在尝试为两个准备好的语句获取数据。 $stmt 代表 contentBox div,$stmt2 代表 staffBox div。

$stmt 有效,成功获取内容框,没有任何错误。由于某种原因,$stmt2 根本没有加载任何结果。

这是我的代码:

<?php

        if ($stmt = $conn->prepare("SELECT `id`, `name` FROM ranks ORDER BY `id` DESC"))
        {
            $stmt->execute();
            $stmt->bind_result($id, $rank);

            while($stmt->fetch())
            {
                echo '<div class="contentBox">
                <div class="contentHeader headerOwner">' . $rank . '</div>
                   <div class="contentInside" style="width:auto;margin:auto;text-align:center;margin-top: -2px;margin-left: 3px;margin-bottom: -4px;">';

                if ($stmt2 = $conn->prepare("SELECT `id`, `username`, `look`, `online` FROM `users` WHERE `rank` = ?"))
                {
                    $stmt2->bind_param('i', $id);
                    $stmt2->execute();
                    $stmt2->bind_result($id2, $username, $look, $online);

                    if ($stmt->num_rows <= 0)
                    {
                        echo '<div class="alert alert-danger">No records found.</div>';
                    }
                    else
                    {
                        while($stmt2->fetch())
                        {
                            echo '<div class="staffBox">
                            <div class="staffPicture" style="background-image: url(\'/media/useravatars/DefaultAvatar.png\');"></div>
                            <div class="staffName">
                            <div class="staffHabbo"><img src="https://www.habbo.nl/habbo-imaging/avatarimage?figure=ca-1801-1408.ch-3334-110-1408.ha-3331-110.hr-115-61.lg-3337-110.hd-180-1007.sh-3338-1408&direction=4&head_direction=4&action=wav&size=s" border="0"/></div>
                            <p style="margin: 5px 0px;font-weight: bold;"><a href="/user/' . $username . '" ng-click="progress()" class="username-black" tooltips="" tooltip-title="' . $username . '">' . $username . '</a></p>
                            <p style="margin: 5px 0px;">Owner</p>
                            <p style="margin: 5px 0px;"><i>United States</i></p>
                            </div></div>';
                        }
                    }

                    $stmt2->close();
                }

                echo '</div>
                </div>';
            }

            $stmt->close();
        }

    ?>

左图是我得到的结果,右图是我应该得到的结果。

左图:

enter image description here

右图:

enter image description here

提前致谢。

最佳答案

除非调用 store_result(),否则不能从单个连接嵌套两个准备好的语句每次查询后。语句对象是指向底层结果集的指针或游标,调用 store_result() 告诉 MySQL 驱动程序将整个结果集提取到内存中,从而允许您设置新的指针。

关于php - 如何为两个准备好的语句获取数据? (MySQLi),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35019639/

相关文章:

java - 自动创建数据库 springboot 和 mysql

mysql - 如何从 mysql 中的字段中提取部分文本?

php - 如何从表 B 中选择属于表 A 的缺失表行?

php - 我们可以合并两个查询,将结果返回为行

PHP:相当于 MySQL 的函数 SUBSTRING_INDEX ?

javascript - html5 canvas - 在 Chrome 上绘制大字体的表情符号后图像数据为空

javascript - 我怎样才能用 webkit-transform 进行足够的翻译,以便

php - 如果 AJAX url 重定向到登录页面,则重定向到登录页面

从开始日期到结束日期的 PHP 空闲时间 block

html - 在简单的 HTML 网站上为背景图像添加微数据