iliaa Sun Jul 22 15:14:21 2007 UTC Modified files: (Branch: PHP_5_2) /php-src/ext/pdo pdo_stmt.c Log: Fixed PDO_FETCH_KEY_PAIR implementation for fetchAll() http://cvs.php.net/viewvc.cgi/php-src/ext/pdo/pdo_stmt.c?r1=1.118.2.38.2.19&r2=1.118.2.38.2.20&diff_format=u Index: php-src/ext/pdo/pdo_stmt.c diff -u php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.19 php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.20 --- php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.19 Tue Jun 26 01:24:10 2007 +++ php-src/ext/pdo/pdo_stmt.c Sun Jul 22 15:14:21 2007 @@ -18,7 +18,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: pdo_stmt.c,v 1.118.2.38.2.19 2007/06/26 01:24:10 iliaa Exp $ */ +/* $Id: pdo_stmt.c,v 1.118.2.38.2.20 2007/07/22 15:14:21 iliaa Exp $ */ /* The PDO Statement Handle Class */ @@ -911,8 +911,9 @@ pdo_raise_impl_error(stmt->dbh, stmt, "HY000", "PDO::FETCH_KEY_PAIR fetch mode requires the result set to contain extactly 2 columns." TSRMLS_CC); return 0; } - - array_init(return_value); + if (!return_all) { + array_init(return_value); + } break; case PDO_FETCH_COLUMN: @@ -1018,7 +1019,7 @@ return 0; } - if (return_all) { + if (return_all && how != PDO_FETCH_KEY_PAIR) { INIT_PZVAL(&grp_val); fetch_value(stmt, &grp_val, i, NULL TSRMLS_CC); convert_to_string(&grp_val); @@ -1044,17 +1045,15 @@ zval *tmp; MAKE_STD_ZVAL(tmp); fetch_value(stmt, tmp, ++i, NULL TSRMLS_CC); - - if (Z_TYPE_P(val) == IS_STRING) { - zend_symtable_update(Z_ARRVAL_P(return_value), Z_STRVAL_P(val), Z_STRLEN_P(val) + 1, &tmp, sizeof(zval *), NULL); - } else if (Z_TYPE_P(val) == IS_LONG) { - zend_hash_index_update(Z_ARRVAL_P(return_value), Z_LVAL_P(val), tmp, sizeof(tmp), NULL); + + if (Z_TYPE_P(val) == IS_LONG) { + zend_hash_index_update((return_all ? Z_ARRVAL_P(return_all) : Z_ARRVAL_P(return_value)), Z_LVAL_P(val), &tmp, sizeof(zval *), NULL); } else { convert_to_string(val); - zend_symtable_update(Z_ARRVAL_P(return_value), Z_STRVAL_P(val), Z_STRLEN_P(val) + 1, &tmp, sizeof(zval *), NULL); + zend_symtable_update((return_all ? Z_ARRVAL_P(return_all) : Z_ARRVAL_P(return_value)), Z_STRVAL_P(val), Z_STRLEN_P(val) + 1, &tmp, sizeof(zval *), NULL); } - zval_dtor(val); - FREE_ZVAL(val); + zval_ptr_dtor(&val); + return 1; } break; @@ -1522,7 +1521,7 @@ if (!error) { PDO_STMT_CLEAR_ERR(); MAKE_STD_ZVAL(data); - if (how & PDO_FETCH_GROUP) { + if (how & (PDO_FETCH_GROUP|PDO_FETCH_KEY_PAIR)) { array_init(return_value); return_all = return_value; } else { @@ -1534,10 +1533,12 @@ } } if (!error) { - if ((how & PDO_FETCH_GROUP)) { + if (how & PDO_FETCH_GROUP) { do { MAKE_STD_ZVAL(data); } while (do_fetch(stmt, TRUE, data, how, PDO_FETCH_ORI_NEXT, 0, return_all TSRMLS_CC)); + } else if (how & PDO_FETCH_KEY_PAIR) { + while (do_fetch(stmt, TRUE, data, how, PDO_FETCH_ORI_NEXT, 0, return_all TSRMLS_CC)); } else { array_init(return_value); do {
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php