That doesn't sound right. It should probably be an error to bind by
number when using named parameters.
Will investigate more.
--Wez.
On 7/11/05, Andrey Hristov <[EMAIL PROTECTED]> wrote:
> andrey Mon Jul 11 10:14:57 2005 EDT
>
> Modified files:
> /php-src/ext/pdo pdo_stmt.c
> Log:
> fix a segfault with the following script:
> <?php
> $dbh = new PDO('mysql:dbname=test;host=localhost', "root", "secret");
> $what = 1;
> $stmt = $dbh->prepare('select a, b, c from t123 where a=:what');
> $stmt->bindParam(1, $what, PDO_PARAM_INT, 12);
> var_dump($stmt->execute());
> var_dump($stmt->fetchObject());
> ?>
>
>
> http://cvs.php.net/diff.php/php-src/ext/pdo/pdo_stmt.c?r1=1.108&r2=1.109&ty=u
> Index: php-src/ext/pdo/pdo_stmt.c
> diff -u php-src/ext/pdo/pdo_stmt.c:1.108 php-src/ext/pdo/pdo_stmt.c:1.109
> --- php-src/ext/pdo/pdo_stmt.c:1.108 Fri Jul 8 23:52:39 2005
> +++ php-src/ext/pdo/pdo_stmt.c Mon Jul 11 10:14:56 2005
> @@ -18,7 +18,7 @@
> +----------------------------------------------------------------------+
> */
>
> -/* $Id: pdo_stmt.c,v 1.108 2005/07/09 03:52:39 wez Exp $ */
> +/* $Id: pdo_stmt.c,v 1.109 2005/07/11 14:14:56 andrey Exp $ */
>
> /* The PDO Statement Handle Class */
>
> @@ -91,7 +91,10 @@
> /* this is not an error here */
> return 1;
> }
> -
> + if (!param->name) {
> + return 1;
> + }
> +
> zend_hash_internal_pointer_reset(stmt->bound_param_map);
> while (SUCCESS ==
> zend_hash_get_current_data(stmt->bound_param_map, (void**)&name)) {
> if (strcmp(name, param->name)) {
>
> --
> PHP CVS Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php