php pdo中bindParam() 和 bindValue()方法的区别
程序员文章站
2022-03-26 18:57:12
...
方法 bindParam() 和 bindValue() 非常相。 唯一的区别就是前者使用一个PHP变量绑定参数,而后者使用一个。 所以使用bindParam是第二个参数只能用变量名,而不能用变量,而bindValue至可以使用具体。 $stm = $pdo-prepare(select * from users where user =
方法 bindParam() 和 bindValue() 非常相似。
唯一的区别就是前者使用一个PHP变量绑定参数,而后者使用一个值。
所以使用bindParam是第二个参数只能用变量名,而不能用变量值,而bindValue至可以使用具体值。
$stm = $pdo->prepare("select * from users where user = :user"); $user = "jack"; //正确 $stm->bindParam(":user",$user); //错误 //$stm->bindParam(":user","jack"); //正确 $stm->bindValue(":user",$user); //正确 $stm->bindValue(":user","jack");
另外在存储过程中,bindParam可以绑定为input/output变量,如下面
$stm = $pdo->prepare("call func(:param1)"); $param1 = "abcd"; $stm->bindParam(":param1",$param1); //正确 $stm->execute();存储过程执行过后的结果可以直接反应到变量上。
对于那些内存中的大数据块参数,处于性能的考虑,应优先使用前者。
via http://anfirst.cn/archives/1030
推荐阅读
-
php中require和require_once的区别说明
-
详解Node.js中path模块的resolve()和join()方法的区别
-
php中数字0和空值的区别分析
-
php中curl和file_get_content的区别
-
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
-
详解PHP中strlen和mb_strlen函数的区别
-
浅析ThinkPHP中execute和query方法的区别
-
PHP中strlen()和mb_strlen()的区别浅析
-
JavaScript中的toString()和toLocaleString()方法的区别
-
PHP中4个加速、缓存扩展的区别和选用建议