两个mysqli查询,一次循环 [英] two mysqli querys, one in a while loop

查看:83
本文介绍了两个mysqli查询,一次循环的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

无法找到答案. 我有一个mysqli循环语句.在这个循环中,我想运行另一个查询.我不能一起写这两个SQL.那可能吗? 我以为,因为我使用了stmt并将其设置为准备语句.所以我添加了另一个变量stmt2.运行它们是分开的,但是像我写的那样运行会给我"mysqli致命错误:在非对象上调用成员函数bind_param()"

Can't seam to find the answer to this. I have a mysqli loop statement. And in that loop I want to run another query. I cant write these two sql together. Is that possible? I thought since I use stmt and set that to prepare statement. So i add another variable stmt2. Running them seperate works, but run it like I wrote it gives me "mysqli Fatal error: Call to a member function bind_param() on a non-object"

伪代码:

loop_sql_Statement {
    loop_another_sql_statement(variable_from_firsT_select) {
       echo "$first_statement_variables    $second_statemenet_variables";
    }
}
                $sql = "select dyr_id, dyr_navn, type_navn, dyr_rase_id, dyr_fodt_aar, dyr_kommentar, dyr_opprettet, dyr_endret
                    from dyr_opphald, dyr, dyr_typer
                    where dyropphald_dyr_id = dyr_id
                    and dyr_type_id = type_id
                    and dyropphald_opphald_id = ?";

            $stmt = $mysqli->prepare($sql);
            $stmt->bind_param("i",
             $p_opphald_id);
            $stmt->execute(); 

            $stmt->bind_result($dyr_id, $dyr_navn, $type_navn, $dyr_rase_id, $dyr_fodt_aar, $dyr_kommentar, $dyr_opprettet, $dyr_endret);

            echo "<table>";
            while($stmt->fetch()) {
                echo "<tr><td>$dyr_navn</td><td>$type_navn</td><td>$dyr_rase_id</td><td>$dyr_fodt_aar</td><td>";

                $sql2 = "select ekstra_ledetekst, ekstradyr_ekstra_verdi from dyr_ekstrainfo, ekstrainfo where ekstradyr_ekstra_id = ekstra_id and ekstradyr_dyr_id = ?";
                try {

                    $stmt2 = $mysqli->prepare($sql2);
                    $stmt2->bind_param("i",
                     $dyr_id);
                    $stmt2->execute(); 

                    $stmt2->bind_result($ekstra_ledetekst, $ekstra_ledetekst);
                    echo "<td>";
                    while($stmt2->fetch()) {
                        echo "$ekstra_ledetekst => $ekstra_ledetekst<br>";
                    }
                }catch (Exception $e) {}
                echo "</td></tr>";
            }
            echo "</table>";


答案:


The answer:

对不起,我不知道我必须有两个mysqli连接.因此解决方案是声明另一个mysqli连接.

Silly me, I didnt know I had to have two mysqli connection. So the solution was to declare another mysqli connection.

$mysqli = new mysqli($start, $name, $pwd, $selected_db);
$mysqli2 = new mysqli($start, $name, $pwd, $selected_db);

推荐答案

您必须能够执行此操作,尽管您必须启动第二个连接.

You should be able to do that, although you make have to start a second connection.

这篇关于两个mysqli查询,一次循环的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆