workaround bug in OCI PDO driver
This commit is contained in:
parent
0be55e05bf
commit
8d63921924
1 changed files with 11 additions and 3 deletions
|
@ -583,9 +583,17 @@ class Database extends AbstractData
|
||||||
{
|
{
|
||||||
$statement = self::$_db->prepare($sql);
|
$statement = self::$_db->prepare($sql);
|
||||||
$statement->execute($params);
|
$statement->execute($params);
|
||||||
$result = $firstOnly ?
|
if ($firstOnly) {
|
||||||
$statement->fetch(PDO::FETCH_ASSOC) :
|
$result = $statement->fetch(PDO::FETCH_ASSOC);
|
||||||
$statement->fetchAll(PDO::FETCH_ASSOC);
|
} elseif (self::$_type === 'oci') {
|
||||||
|
// workaround for https://bugs.php.net/bug.php?id=46728
|
||||||
|
$result = array();
|
||||||
|
while ($row = $statement->fetch(PDO::FETCH_ASSOC)) {
|
||||||
|
$result[] = $row;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$result = $statement->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
}
|
||||||
$statement->closeCursor();
|
$statement->closeCursor();
|
||||||
if (self::$_type === 'oci' && is_array($result)) {
|
if (self::$_type === 'oci' && is_array($result)) {
|
||||||
// returned column names are all upper case, convert these back
|
// returned column names are all upper case, convert these back
|
||||||
|
|
Loading…
Reference in a new issue