What is the difference between bindParam and bindValue?

后端 未结 7 1259
一向
一向 2020-11-22 00:23

What is the difference between PDOStatement::bindParam() and PDOStatement::bindValue()?

相关标签:
7条回答
  • 2020-11-22 01:11

    From the manual entry for PDOStatement::bindParam:

    [With bindParam] Unlike PDOStatement::bindValue(), the variable is bound as a reference and will only be evaluated at the time that PDOStatement::execute() is called.

    So, for example:

    $sex = 'male';
    $s = $dbh->prepare('SELECT name FROM students WHERE sex = :sex');
    $s->bindParam(':sex', $sex); // use bindParam to bind the variable
    $sex = 'female';
    $s->execute(); // executed with WHERE sex = 'female'
    

    or

    $sex = 'male';
    $s = $dbh->prepare('SELECT name FROM students WHERE sex = :sex');
    $s->bindValue(':sex', $sex); // use bindValue to bind the variable's value
    $sex = 'female';
    $s->execute(); // executed with WHERE sex = 'male'
    
    0 讨论(0)
  • 2020-11-22 01:14

    Here are some I can think about :

    • With bindParam, you can only pass variables ; not values
    • with bindValue, you can pass both (values, obviously, and variables)
    • bindParam works only with variables because it allows parameters to be given as input/output, by "reference" (and a value is not a valid "reference" in PHP) : it is useful with drivers that (quoting the manual) :

    support the invocation of stored procedures that return data as output parameters, and some also as input/output parameters that both send in data and are updated to receive it.

    With some DB engines, stored procedures can have parameters that can be used for both input (giving a value from PHP to the procedure) and ouput (returning a value from the stored proc to PHP) ; to bind those parameters, you've got to use bindParam, and not bindValue.

    0 讨论(0)
  • 2020-11-22 01:16

    The simplest way to put this into perspective for memorization by behavior (in terms of PHP):

    • bindParam: reference
    • bindValue: variable
    0 讨论(0)
  • 2020-11-22 01:18

    From Prepared statements and stored procedures

    Use bindParam to insert multiple rows with one time binding:

    <?php
    
    $stmt = $dbh->prepare("INSERT INTO REGISTRY (name, value) VALUES (?, ?)");
    $stmt->bindParam(1, $name);
    $stmt->bindParam(2, $value);
    
    // insert one row
    $name = 'one';
    $value = 1;
    $stmt->execute();
    
    // insert another row with different values
    $name = 'two';
    $value = 2;
    $stmt->execute();
    
    0 讨论(0)
  • 2020-11-22 01:22

    For the most common purpose, you should use bindValue.

    bindParam has two tricky or unexpected behaviors:

    • bindParam(':foo', 4, PDO::PARAM_INT) does not work, as it requires passing a variable (as reference).
    • bindParam(':foo', $value, PDO::PARAM_INT) will change $value to string after running execute(). This, of course, can lead to subtle bugs that might be difficult to catch.

    Source: http://php.net/manual/en/pdostatement.bindparam.php#94711

    0 讨论(0)
  • 2020-11-22 01:24

    The answer is in the documentation for bindParam:

    Unlike PDOStatement::bindValue(), the variable is bound as a reference and will only be evaluated at the time that PDOStatement::execute() is called.

    And execute

    call PDOStatement::bindParam() to bind PHP variables to the parameter markers: bound variables pass their value as input and receive the output value, if any, of their associated parameter markers

    Example:

    $value = 'foo';
    $s = $dbh->prepare('SELECT name FROM bar WHERE baz = :baz');
    $s->bindParam(':baz', $value); // use bindParam to bind the variable
    $value = 'foobarbaz';
    $s->execute(); // executed with WHERE baz = 'foobarbaz'
    

    or

    $value = 'foo';
    $s = $dbh->prepare('SELECT name FROM bar WHERE baz = :baz');
    $s->bindValue(':baz', $value); // use bindValue to bind the variable's value
    $value = 'foobarbaz';
    $s->execute(); // executed with WHERE baz = 'foo'
    
    0 讨论(0)
提交回复
热议问题