From 626302a5617cc253d5db4db731109a991ae71c0f Mon Sep 17 00:00:00 2001 From: Glen Sawyer Date: Thu, 21 Jan 2016 12:10:47 -0700 Subject: [PATCH] Do not buffer results for non-SELECT statements (insert, update, delete) --- src/Driver/Oracle.php | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/Driver/Oracle.php b/src/Driver/Oracle.php index dd137cb..f9f9f05 100644 --- a/src/Driver/Oracle.php +++ b/src/Driver/Oracle.php @@ -3,12 +3,12 @@ use Cake\Database\Driver; use Cake\Database\Driver\PDODriverTrait; +use Cake\Database\Query; use Cake\Database\Statement\PDOStatement; use Cake\Oracle\Dialect\OracleDialectTrait; use Cake\Oracle\Schema\OracleSchema; use Cake\Oracle\Statement\Oci8Statement; use Cake\Oracle\Statement\OracleStatement; -use Cake\ORM\Query; use PDO; use yajra\Pdo\Oci8; @@ -97,15 +97,17 @@ public function connect() public function prepare($query) { $this->connect(); - $isObject = ($query instanceof Query) || ($query instanceof \Cake\Database\Query); + $isObject = ($query instanceof Query); $queryStringRaw = $isObject ? $query->sql() : $query; $queryString = $this->_fromDualIfy($queryStringRaw); $yajraStatement = $this->_connection->prepare($queryString); $oci8Statement = new Oci8Statement($yajraStatement); //Need to override some un-implemented methods in yajra Oci8 "Statement" class $statement = new OracleStatement(new PDOStatement($oci8Statement, $this), $this); //And now wrap in a Cake-ified, bufferable Statement $statement->queryString = $queryStringRaw; //Oci8PDO does not correctly set read-only $queryString property, so we have a manual override - if ($isObject && $query->bufferResults() === false) { - $statement->bufferResults(false); + if ($isObject) { + if ($query->bufferResults() === false || $query->type() != 'select') { + $statement->bufferResults(false); + } } return $statement; }