Skip to content

Commit

Permalink
fix a possible "ORA-01000: maximum open cursors exceeded" when many n…
Browse files Browse the repository at this point in the history
…on-SELECTs are executed
  • Loading branch information
derflocki committed Mar 24, 2016
1 parent fab61b2 commit e474423
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 6 deletions.
5 changes: 4 additions & 1 deletion lib/Doctrine/Adapter/Statement/Oracle.php
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,10 @@ public function bindParam($column, &$variable, $type = null, $length = null, $dr
public function closeCursor()
{
$this->bindParams = array();
return oci_free_statement($this->statement);
if(is_resource($this->statement)) {
return oci_free_statement($this->statement);
}
return true;
}

/**
Expand Down
24 changes: 19 additions & 5 deletions lib/Doctrine/Connection/Statement.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,15 @@ public function __construct(Doctrine_Connection $conn, $stmt)
throw new Doctrine_Exception('Unknown statement object given.');
}
}

/**
* destructor
*
* make sure that the cursor is closed
*
* */
public function __destruct() {
$this->closeCursor();
}
/**
* getConnection
* returns the connection object this statement uses
Expand Down Expand Up @@ -261,13 +269,19 @@ public function execute($params = null)

$this->_conn->getListener()->postStmtExecute($event);

return $result;
} catch (PDOException $e) {
$result = false;
$this->_conn->rethrowException($e, $this);
} catch (Doctrine_Adapter_Exception $e) {
$result = false;
$this->_conn->rethrowException($e, $this);
} finally {
//fix a possible "ORA-01000: maximum open cursors exceeded" when many non-SELECTs are executed
if (strtoupper(substr($this->_stmt->queryString,0,6)) != 'SELECT' && strtoupper(substr($this->_stmt->queryString,0,4)) != 'WITH' ){
$this->closeCursor();
}
return $result;
}

$this->_conn->rethrowException($e, $this);

return false;
}

Expand Down

0 comments on commit e474423

Please sign in to comment.