Is the leading colon for parameter names passed to PDOStatement::bindParam() optional?(传递给 PDOStatement::bindParam() 的参数名称的前导冒号是可选的吗?)
问题描述
将 :name
形式的命名参数传递给 PDOStatement::bindParam()
,不管是否使用前导冒号似乎都有效.
When passing named parameters of the form :name
to PDOStatement::bindParam()
, it seems to work whether or not the leading colon is used.
即要么这样:
$statement->bindParam(':name', $var);
或者这个:
$statement->bindParam('name', $var);
似乎有效.
这里是 PDOStatement::bindParam()
参数
参数标识符.对于使用命名的准备好的语句占位符,这将是 :name. 形式的参数名称.使用问号占位符准备好的语句,这将是1-参数的索引位置.
Parameter identifier. For a prepared statement using named placeholders, this will be a parameter name of the form :name. For a prepared statement using question mark placeholders, this will be the 1-indexed position of the parameter.
这是否意味着可以省略冒号?
Does this mean the colon can be left off?
推荐答案
不,因为文档没有提到这一点,我认为可以安全地假设这种行为不受官方支持,不应依赖.
No, since the documentation doesn't mention this I think it's safe to assume that this behaviour isn't officially supported and shouldn't be relied upon.
但是,它确实可以正常工作(至少在 PHP 5.3.24 中) - 如果缺少冒号,内部会在参数中添加一个冒号(参见 PHP 5.3.24 中的ext/pdo/pdo_stmt.c:363
源代码).
However, it does actually happen to work (in PHP 5.3.24 at least) - internally a colon will be added to the parameter if it's missing (see ext/pdo/pdo_stmt.c:363
in the PHP 5.3.24 source code).
这篇关于传递给 PDOStatement::bindParam() 的参数名称的前导冒号是可选的吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:传递给 PDOStatement::bindParam() 的参数名称的前导冒号是可选的吗?
基础教程推荐
- phpmyadmin 错误“#1062 - 密钥 1 的重复条目‘1’" 2022-01-01
- HTTP 与 FTP 上传 2021-01-01
- 在 CakePHP 2.0 中使用 Html Helper 时未定义的变量 2021-01-01
- 使用 PDO 转义列名 2021-01-01
- 在 yii2 中迁移时出现异常“找不到驱动程序" 2022-01-01
- Doctrine 2 - 在多对多关系中记录更改 2022-01-01
- 如何在 Symfony 和 Doctrine 中实现多对多和一对多? 2022-01-01
- PHP 守护进程/worker 环境 2022-01-01
- 找不到类“AppHttpControllersDB",我也无法使用新模型 2022-01-01
- 如何在 XAMPP 上启用 mysqli? 2021-01-01