登录  /  注册

PHP中bindParam和bindValue的区别

藏色散人
发布: 2019-02-22 10:23:02
原创
3430人浏览过

PHP中bindParam和bindValue的区别

PDOStatement :: bindParam()函数是PHP中的内置函数,用于将参数绑定到指定的变量名。此函数绑定变量,将其值作为输入传递,并接收其相关参数标记的输出值(如果有)。

语法:

bool PDOStatement::bindParam
( $parameter, $variable, $data_type, $length, $driver_options )
登录后复制

参数:此函数接受如上所述的五个参数,如下所述:

$parameter:它是一个参数标识符,用于使用名称占位符准备语句。它是表单的参数名称:name。

$variable:此参数用于保存要绑定到SQL语句参数的变量名称。

$data_type:它是使用PDO :: PARAM_ *常量的参数的显式数据类型。

$length:此参数用于保存数据类型的长度。

$driver_options:该参数保存需要执行的操作。

返回值:此函数成功时返回True,失败时返回false。

程序:

<?php   
  
// 设置PDO连接 
$db = new PDO(&#39;mysql:host=localhost;dbname=phps&#39;,&#39;root&#39;,&#39;&#39;);  
  
// 获得用户名
$username = &#39;phpforphp&#39;; 
     
$stmt = $db->prepare("SELECT * FROM users WHERE user = :username"); 
  
// 使用bindParam函数
$stmt->bindParam(&#39;:username&#39;, $username); 
   
 $username = &#39;g4g&#39;; 
     
 $stmt->execute(); 
?>
登录后复制

注意: SQL语句将使用'g4g'作为用户名执行,因为:username在执行时搜索$ username,$ username的最后一个已知值是'g4g'。

PDOStatement :: bindValue()函数是PHP中的内置函数,用于将值绑定到参数。此函数将值绑定到SQL中用于准备语句的相应命名或问号占位符。

语法:

bool PDOStatement::bindValue( $parameter, $value, $data_type )
登录后复制

参数:此函数接受上述三个参数,如下所述:

$parameter:它是一个参数标识符,用于使用名称占位符准备语句。它是表单的参数名称:name。

$value:此参数用于保存绑定参数的值。

$data_type:它是使用PDO :: PARAM_ *常量的参数的显式数据类型。

返回值:此函数成功时返回True,失败时返回False。

程序:

<?php   
  
// 设置PDO连接
$db = new PDO(&#39;mysql:host=localhost;dbname=phps&#39;,&#39;root&#39;,&#39;&#39;);  
  
// 获得用户名
$username = &#39;phpforphp&#39;; 
    
$stmt = $db->prepare("SELECT * FROM users WHERE user = :username"); 
  
// 使用bindValue函数
$stmt->bindValue(&#39;:username&#39;, $username); 
  
$username = &#39;g4g&#39;; 
    
$stmt->execute(); 
?>
登录后复制

注意: SQL语句将使用'g4g'作为用户名执行,因为文字值“phpforphp”已绑定到:bindValue()函数之前的用户名。$username的进一步更改不会反映在准备好的声明中。

bindParam()和bindValue()之间的区别:

bindParam()

bindParam()函数将参数绑定到SQL语句中的命名或问号占位符。

bindParam()函数用于传递变量而不是值。

bindValue()

bindValue()函数将值绑定到SQL语句中的命名或问号。

bindValue()函数用于传递值和变量。

推荐:《PHP教程http://www.php.cn/course/list/29.html

本篇文章就是关于PHP中bindParam和bindValue的区别介绍,希望对需要的朋友有所帮助!

以上就是PHP中bindParam和bindValue的区别的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号