为两个准备好的语句使用相同的MySql连接

时间:2014-04-27 17:34:44

标签: php mysql mysqli prepared-statement

所以我的PHP代码存在问题,我正在尝试运行两个准备好的语句,这些语句已经用相同的$ mysqli对象进行了准备。

        require 'database.php';
        $mysqli = new mysqli($database_host, $database_user, $database_pass, $database_name);

        /*First check if there is already a preference record for this user
          with this particular course.*/
        $query = "SELECT * FROM timetablePrefs WHERE username=? AND courseID=?";
        $stmt = $mysqli->prepare($query);
        foreach ($courseList as $key => $value)
        {
            $stmt->bind_param("ss", $username, $key);
            $stmt->execute();
            if (($stmt->num_rows) === 1)
                continue;
            else
            {
                $query = "INSERT INTO timetablePrefs (username, courseID, hexColour, hidden) ";
                $query .= "VALUES (?, ?, ?, 0)";
                $prepared = $mysqli->prepare($query);
                $prepared->bind_param("sss", $username, $key, "#FFFFFF");
                if (!($prepared->execute()))
                    print("Sorry couldnt change your colour preferences.");
                $prepared->close();
            }
        }
        $stmt->close();
        $mysqli->close();

我可能在这里遗漏了一些东西;你甚至可以同时运行其中两个吗?任何帮助将不胜感激!有任何问题请询问;)

我收到的错误是关于线路的;     $prepared->bind_param("sss", $username, $key, "#FFFFFF"); 致命错误:在非对象上调用成员函数bind_param()

2 个答案:

答案 0 :(得分:1)

  1. To get the actual error
  2. To solve it。从错误中可以看出,上一个查询的结果是未决的。需要存储它们

答案 1 :(得分:-2)

我正在以程序方式做我的事情,但也有同样的问题。所以我创建了两个不同的数据库连接变量(只是一个黑客而不是正确的解决方案),而不是这样做:

stmt_pnl = mysqli_stmt_init($conn);
stmt_bank = mysqli_stmt_init($conn);

我做到了:

stmt_pnl = mysqli_stmt_init($conn);
stmt_bank = mysqli_stmt_init($conn_bank);

错误消失了,它起作用了。

编辑:上面的答案只是解决问题的技巧,而不是实际的解决方案。解决此错误的正确方法是遵循以下顺序:

  1. 准备语句(初始化和绑定参数)
  2. 执行语句
  3. 获取结果 (mysqli_stmt_get_result)
  4. 结束声明。

(特别感谢你的常识)