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() 的参数名称的前导冒号是可选的吗?
基础教程推荐
- YouTube API v3 点赞视频,但计数器不增加 2022-01-01
- 学说 dbal querybuilder 作为准备好的语句 2022-01-01
- 有什么方法可以用编码 UTF-8 而不是 Unicode 返回 PHP`json_encode`? 2021-01-01
- 在PHP中根据W3C规范Unicode 2022-01-01
- 如何在 Laravel 5.3 注册中添加动态下拉列表列? 2021-01-01
- 如何替换eregi() 2022-01-01
- PHP 类:全局变量作为类中的属性 2021-01-01
- Cron Jobs 调用带有变量的 PHP 脚本 2022-01-01
- PHP PDO MySQL 查询 LIKE ->多个关键词 2021-01-01
- 如何在 Laravel 中使用 React Router? 2022-01-01
