diff options
author | George Wang <gwang@php.net> | 2015-06-22 23:39:53 -0400 |
---|---|---|
committer | George Wang <gwang@php.net> | 2015-06-22 23:39:53 -0400 |
commit | b0954ebb79faf53176e528dd9a3038d2a16ab1ef (patch) | |
tree | 76f9dacf00a2fe17215e355979ec0357384914d1 /ext/pdo_pgsql/pgsql_statement.c | |
parent | 8877feaeec7442c459eb923a00ad6ce68edf186a (diff) | |
parent | 5fe078abba7dc87ecc05fa3b9bf544867e947567 (diff) | |
download | php-git-b0954ebb79faf53176e528dd9a3038d2a16ab1ef.tar.gz |
Merge branch 'PHP-5.5' of git.php.net:php-src into PHP-5.5
Diffstat (limited to 'ext/pdo_pgsql/pgsql_statement.c')
-rw-r--r-- | ext/pdo_pgsql/pgsql_statement.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/ext/pdo_pgsql/pgsql_statement.c b/ext/pdo_pgsql/pgsql_statement.c index f541c86259..51402c3e53 100644 --- a/ext/pdo_pgsql/pgsql_statement.c +++ b/ext/pdo_pgsql/pgsql_statement.c @@ -220,7 +220,7 @@ stmt_retry: return 0; } - if (!stmt->executed && !stmt->column_count) { + if (!stmt->executed && (!stmt->column_count || S->cols == NULL)) { stmt->column_count = (int) PQnfields(S->result); S->cols = ecalloc(stmt->column_count, sizeof(pdo_pgsql_column)); } @@ -294,8 +294,8 @@ static int pgsql_stmt_param_hook(pdo_stmt_t *stmt, struct pdo_bound_param_data * sizeof(Oid)); } if (param->paramno >= 0) { - if (param->paramno >= zend_hash_num_elements(stmt->bound_param_map)) { - pdo_pgsql_error_stmt(stmt, PGRES_FATAL_ERROR, "HY105"); + if (param->paramno >= zend_hash_num_elements(stmt->bound_params)) { + pdo_raise_impl_error(stmt->dbh, stmt, "HY093", "parameter was not defined" TSRMLS_CC); return 0; } @@ -614,6 +614,12 @@ done: static int pdo_pgsql_stmt_cursor_closer(pdo_stmt_t *stmt TSRMLS_DC) { + pdo_pgsql_stmt *S = (pdo_pgsql_stmt*)stmt->driver_data; + + if (S->cols != NULL){ + efree(S->cols); + S->cols = NULL; + } return 1; } |