首页 > php教程 > php手册 > 正文

php pdo中bindParam() 和 bindValue()方法的区别

WBOY
发布: 2016-06-06 19:44:49
原创
1079 人浏览过

方法 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.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!