您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

PHP PDO :: bindParam()数据类型..它如何工作?

PHP PDO :: bindParam()数据类型..它如何工作?

在其他语言的其他数据库抽象框架中,它可用于确保诸如对内联值进行正确的转义(对于不支持正确绑定参数的驱动程序)以及通过确保数字是否正确来提高网络效率。适当打包二进制文件(提供协议支持)。看起来像在PDO中,它并没有做太多事情。

   if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_STR && param->max_value_len <= 0 && ! ZVAL_IS_NULL(param->parameter)) {
                if (Z_TYPE_P(param->parameter) == IS_DOUBLE) {
                        char *p;
                        int len = spprintf(&p, 0, "%F", Z_DVAL_P(param->parameter));
                        ZVAL_STRINGL(param->parameter, p, len, 0);
                } else {
                        convert_to_string(param->parameter);
                }
        } else if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_INT && Z_TYPE_P(param->parameter) == IS_BOOL) {
                convert_to_long(param->parameter);
        } else if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_BOOL && Z_TYPE_P(param->parameter) == IS_LONG) {
                convert_to_boolean(param->parameter);
        }

因此,如果您说它是STR(或者您什么也不说,因为这是认值),并且您的数据的内部类型是double,那么它将使用一种方法将其转换为字符串,如果不是double,则它将会使用其他方法将其转换为字符串。

如果您说这是一个整数,但实际上是布尔值,那么它将把它转换为long。

如果您说的是布尔值,但实际上是一个数字,那么它将把它转换为真正的布尔值。

我实际上是(快速地)查看了stmt源代码,我想一旦将参数传递到驱动程序中,它们就可以做更多的事情。因此,我想您所获得的只是一点点正确的做,以及驾驶员之间很多行为的歧义和差异。

php 2022/1/1 18:18:19 有490人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶