PDO 准备语句:参数名称中的冒号表示什么?
简介
何时使用具有命名参数的 PDO,一些开发人员在参数名称前添加冒号 (:),而其他开发人员则在参数名称前添加冒号 (:)完全忽略它们。虽然这两种方法似乎都有效,但这些冒号的意义一直是一个好奇的话题。
语法要求
在 SQL 字符串中,命名占位符需要具有PHP 文档中所述的冒号。这是因为它有助于明确的参数识别。
$insertRecord = $conn->prepare('INSERT INTO Table1 (column1, column2) VALUES(:column1, :column2)'); // ^ ^ note the colons
绑定和执行中的可选冒号
与 SQL 字符串不同,冒号在 PDOStatement 中是可选的:: bindParam() 和 PDOStatement::execute()。下面是一个使用冒号和不使用冒号绑定和执行语句的示例:
$insertRecord->execute(array( ':column1' => $column1, ':column2' => $column2 )); // or $insertRecord->execute(array( 'column1' => $column1, 'column2' => $column2 ));
它的工作原理
通过检查 PHP 源代码,我们发现解释器占位符中只需要一个冒号。因此,:name 有效,而 name 和 ::name 无效。
这使得解释器能够假设在bindParam() 或execute() 中名为name 的参数实际上应该是:name。 pdo_stmt.c 文件演示了此行为。因此,PHP 会自动将冒号添加到缺少冒号的参数名称中。
最佳实践
从技术上讲,这两种方法都有效。但是,为了在 IDE 中保持一致性、可读性和易于搜索,建议使用冒号。这种方法消除了歧义并符合公认的最佳实践。
以上是PDO 准备语句:参数名称中是否需要冒号?的详细内容。更多信息请关注PHP中文网其他相关文章!