8

我正在转换为 PDO 并使用准备好的语句,我想绑定我的结果,$stmt->bind_result($email_count);因此我可以将其放入 if 语句中以查看电子邮件是否存在但是我收到与Fatal error: Call to undefined method PDOStatement::bind_result() in /Applications/XAMPP/xamppfiles/htdocs/imanage/insert.php on line 51上一个相关的错误例子。

我猜 bind_result 不是 PDO 定义的方法,那么我可以使用等效的方法吗?

如果有帮助,我的代码如下:

插入.php

<?php

 include("connect/class.Database.php");

 class Users extends Database {

     public function insert() {

            $stmt = $this->pdo->prepare("SELECT COUNT(*) FROM users WHERE email=:email");
            $stmt->bindParam(":email", $_POST['email']);
            $stmt->bind_result($email_count);
            $stmt->execute();
            $stmt->fetch(PDO::FETCH_ASSOC);

                    if ($email_count > 0) {
                        echo "email exisits! click here to try <a href='register'>again</a>";
                        } else {
                            //escape the POST data for added protection
                            $username = isset($_POST['username']) ? $_POST['username'] : null;
                            $cryptedPassword = crypt($_POST['password']);
                            $password = $cryptedPassword;
                            $name = isset($_POST['name']) ? $_POST['name'] : null;
                            $email = isset($_POST['email']) ? $_POST['email'] : null;

                            $data = array($username, $password, $name, $email); 
                            $stmta = $this->pdo->prepare("INSERT INTO users (username, password, name, email) VALUES (?, ?, ?, ?)");
                            $stmta->execute($data);

                                printf("%d Row inserted.\n", $stmta->row_count);
                                /* close statement and connection */
                                $stmta->close();
                } // end email_count and insert to table
            } // end function

      }
?>

连接/类.Database.php

<?php

// Database connection PDO

class Database {

    public function __construct() {
        // Connection information
        $host   = 'localhost';
        $dbname = 'imanage';
        $user   = 'root';
        $pass   = '';

        // Attempt DB connection
        try
        {
            $this->pdo = new PDO("mysql:host=$host;dbname=$dbname", $user, $pass);
            $this->pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            echo 'Successfully connected to the database!';
        }
        catch(PDOException $e)
        {
            echo $e->getMessage();
        }

    }

     public function __destruct()
    {
        // Disconnect from DB
        $this->pdo = null;
        echo 'Successfully disconnected from the database!';
    }


}

?>
4

4 回答 4

9

您根本不需要带有 PDO 的丑陋 bind_result。

然而你也不需要计算。请避免不必要的操作 - 它们只会无缘无故地膨胀和混淆您的代码。

首先想一想,您需要从查询中得到什么?你真的需要数数吗?不,您真正需要的只是一个标志 - 如果用户存在或不存在。因此,进行查询以返回这样的标志。

$stmt = $this->pdo->prepare("SELECT 1 FROM users WHERE email=?");
$stmt->execute(array($_POST['email']));
$exists = $stmt->fetchColumn();

代码的所有其他部分也是如此

//escape the POST data for added protection

您实际上并没有“转义”此代码块中的任何数据,也没有添加任何保护。然而,我认为将 NULL 作为电子邮件插入绝对没有意义。你确定你真的想要吗?

于 2013-09-10T04:52:16.490 回答
4

要从查询之类的内容中快速检索值SELECT COUNT(),请查看PDOStatement::fetchColumn,例如

$stmt = $pdo->prepare('SELECT COUNT(1) FROM users WHERE email = :email');
$stmt->bindParam(':email', $email);
$stmt->execute();
$email_count = $stmt->fetchColumn();

我还想提供一些进一步的建议。您不应该PDO在类构造函数中创建连接。这意味着每次实例化扩展类时Database,都会创建一个新连接。相反,将PDO实例作为依赖项传递,例如

abstract class Database {
    /**
     * @var PDO
     */
    protected $pdo;

    public function __construct(PDO $pdo) {
        $this->pdo = $pdo;
    }
}

你的User::insert方法也是如此。尝试通过方法参数传递任何必需的参数。如果您想开始为您的课程编写单元测试,这将是无价的

public function insert($email) {
    $stmt = $this->pdo->prepare('SELECT COUNT(1) FROM users WHERE email = :email');
    $stmt->bindParam(':email', $email);
    $stmt->execute();
    $email_count = $stmt->fetchColumn();

    // and so on

最后,对于仅限 PHP 的文件,省略结束 PHP 标记?>。这将使您避免在可能发送到浏览器的文件末尾意外包含空格。

于 2013-09-10T00:36:38.750 回答
2

对于来这里寻求字面答案的人。

利用bindColumn

PDOStatement::bindColumn — 将列绑定到 PHP 变量

使用来自同一来源的示例:

function readData($dbh) {
  $sql = 'SELECT name, colour, calories FROM fruit';
  try {
    $stmt = $dbh->prepare($sql);
    $stmt->execute();

    /* Bind by column number */
    $stmt->bindColumn(1, $name);
    $stmt->bindColumn(2, $colour);

    /* Bind by column name */
    $stmt->bindColumn('calories', $cals);

    while ($row = $stmt->fetch(PDO::FETCH_BOUND)) {
      $data = $name . "\t" . $colour . "\t" . $cals . "\n";
      print $data;
    }
  }
  catch (PDOException $e) {
    print $e->getMessage();
  }
}
readData($dbh);
于 2018-01-15T10:09:03.043 回答
0

这是我的自定义函数:

function bindColumns($stmt, $columns){
    if(!is_array($columns)) $columns=array($columns);
    $count=count($columns);
    for($i=0;$i<$count;$i++) $stmt->bindColumn($i+1, $columns[$i]);
}

和用法(参考变量):

bindColumns($stmt, array(&$worker_id, &$password, &$salt));
于 2015-08-17T05:06:57.743 回答