2006-05-30 13:02:35 +04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* oracle driver
|
|
|
|
*/
|
|
|
|
class Doctrine_Session_Oracle extends Doctrine_Session {
|
2006-08-16 01:32:33 +04:00
|
|
|
/**
|
|
|
|
* Adds an driver-specific LIMIT clause to the query
|
|
|
|
*
|
|
|
|
* @param string $query
|
|
|
|
* @param mixed $limit
|
|
|
|
* @param mixed $offset
|
|
|
|
*/
|
2006-05-30 13:02:35 +04:00
|
|
|
public function modifyLimitQuery($query,$limit,$offset) {
|
|
|
|
$e = explode("select ",strtolower($query));
|
|
|
|
$e2 = explode(" from ",$e[1]);
|
|
|
|
$fields = $e2[0];
|
|
|
|
|
|
|
|
$query = "SELECT $fields FROM (SELECT rownum as linenum, $fields FROM ($query) WHERE rownum <= ($offset + $limit)) WHERE linenum >= ".++$offset;
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* returns the next value in the given sequence
|
|
|
|
* @param string $sequence
|
|
|
|
* @return integer
|
|
|
|
*/
|
|
|
|
public function getNextID($sequence) {
|
|
|
|
$stmt = $this->query("SELECT $sequence.nextval FROM dual");
|
|
|
|
$data = $stmt->fetch(PDO::FETCH_NUM);
|
|
|
|
return $data[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|