FIX PDO in PHP 8

This commit is contained in:
Steve Boyd 2022-06-30 12:34:05 +12:00
parent 01c27e69de
commit 3a0fff25de

View File

@ -7,6 +7,7 @@ use SilverStripe\Dev\Deprecation;
use PDO; use PDO;
use PDOStatement; use PDOStatement;
use InvalidArgumentException; use InvalidArgumentException;
use PDOException;
/** /**
* PDO driver database connector * PDO driver database connector
@ -109,10 +110,15 @@ class PDOConnector extends DBConnector implements TransactionManager
} }
// Generate new statement // Generate new statement
try {
$statement = $this->pdoConnection->prepare( $statement = $this->pdoConnection->prepare(
$sql, $sql,
[PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY] [PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY]
); );
} catch (PDOException $e) {
$statement = false;
$this->databaseError($e->getMessage(), E_USER_ERROR, $sql);
}
// Wrap in a PDOStatementHandle, to cache column metadata // Wrap in a PDOStatementHandle, to cache column metadata
$statementHandle = ($statement === false) ? false : new PDOStatementHandle($statement); $statementHandle = ($statement === false) ? false : new PDOStatementHandle($statement);
@ -557,9 +563,14 @@ class PDOConnector extends DBConnector implements TransactionManager
} }
} }
// Note: $this->inTransaction may not match the 'in-transaction' state in PDO
$this->inTransaction = false; $this->inTransaction = false;
if ($this->pdoConnection->inTransaction()) {
return $this->pdoConnection->rollBack(); return $this->pdoConnection->rollBack();
} }
// return false because it did not rollback.
return false;
}
public function transactionDepth() public function transactionDepth()
{ {