加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 为什么MySQLi库本身不支持命名参数?

发布时间:2020-12-13 13:23:57 所属栏目:PHP教程 来源:网络整理
导读:从 http://php.net/manual/en/mysqli.quickstart.prepared-statements.php开始正确的MySQLi参数化查询语法: $stmt = $mysqli-prepare("INSERT INTO test(id) VALUES (?)");$stmt-bind_param("i",$id); 但从来没有像: $stmt = $mysqli-prepare("INSERT INTO
从 http://php.net/manual/en/mysqli.quickstart.prepared-statements.php开始正确的MySQLi参数化查询语法:
$stmt = $mysqli->prepare("INSERT INTO test(id) VALUES (?)");
$stmt->bind_param("i",$id);

但从来没有像:

$stmt = $mysqli->prepare("INSERT INTO test(id) VALUES (:id_value)");
$stmt->bind_param("i","id_value",$id);

在我看来,命名参数替换是在API级别实现的合理特性.我很惊讶MySQLi只在库中实现了未命名的参数.

有正当理由吗?对我来说没有意义,看看PDO,DQL,ORM如何在他们的查询中采用命名参数.

我希望MySQLi开发人员不会遇到“我们懒惰而且不想要”的情况.我相信一定有充分的理由,我正在寻找这个理由,或者寻找理由. MySQLi扩展库中未实现命名参数的原因.

MYSQLi不支持命名参数,因为它的对应物PDO也支持.并且您使用当时最适合您需求的方法……

两者都是用PHP 5发布的(我相信PDO版本为5.3).

那么……你想要更快的执行时间?使用MYSQLi.你想要命名参数吗?使用PDO.

您希望MYSQLi使用客户端命名参数吗?好吧,现在你刚刚失去了更快的执行时间……我想你可以看到它的发展方向……

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读