From: Frank M. Kromann Date: Tue, 4 Apr 2006 18:50:16 +0000 (+0000) Subject: MFP51: Fix #33694 invalid sql or timeouts makes it impossible to reuse persistent... X-Git-Tag: php-4.4.3RC1~28 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=018dc1e52ea062aa1d39445e1de543f745db65f1;p=php MFP51: Fix #33694 invalid sql or timeouts makes it impossible to reuse persistent connections --- diff --git a/ext/mssql/php_mssql.c b/ext/mssql/php_mssql.c index b780b31bb3..eea62134ff 100644 --- a/ext/mssql/php_mssql.c +++ b/ext/mssql/php_mssql.c @@ -222,6 +222,7 @@ static void _free_mssql_result(zend_rsrc_list_entry *rsrc TSRMLS_DC) mssql_result *result = (mssql_result *)rsrc->ptr; _free_result(result, 1); + dbcancel(result->mssql_ptr->link); efree(result); } @@ -1230,6 +1231,7 @@ PHP_FUNCTION(mssql_query) } if (dbsqlexec(mssql_ptr->link)==FAIL || (retvalue = dbresults(mssql_ptr->link))==FAIL) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Query failed"); + dbcancel(mssql_ptr->link); RETURN_FALSE; } @@ -1244,6 +1246,7 @@ PHP_FUNCTION(mssql_query) retvalue=dbnextrow(mssql_ptr->link); if (retvalue==FAIL) { + dbcancel(mssql_ptr->link); RETURN_FALSE; } @@ -2182,6 +2185,7 @@ PHP_FUNCTION(mssql_execute) if (dbrpcexec(mssql_ptr->link)==FAIL || dbsqlok(mssql_ptr->link)==FAIL) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "stored procedure execution failed"); + dbcancel(mssql_ptr->link); RETURN_FALSE; } @@ -2189,6 +2193,7 @@ PHP_FUNCTION(mssql_execute) if (retval_results==FAIL) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "could not retrieve results"); + dbcancel(mssql_ptr->link); RETURN_FALSE; }