You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
1.9 KiB
75 lines
1.9 KiB
<?php |
|
|
|
namespace yii\db\oci; |
|
|
|
use yii\db\Exception; |
|
use yii\base\InvalidParamException; |
|
|
|
/** |
|
* QueryBuilder is the query builder for MySQL databases. |
|
* |
|
* @author Qiang Xue <qiang.xue@gmail.com> |
|
* @since 2.0 |
|
*/ |
|
class QueryBuilder extends \yii\db\QueryBuilder { |
|
|
|
private $sql; |
|
|
|
public function build($query) { |
|
//var_dump($query);exit; |
|
$params = $query->params; |
|
$clauses = [ |
|
$this->buildSelect($query->select, $query->distinct, $query->selectOption), |
|
$this->buildFrom($query->from), |
|
$this->buildJoin($query->join, $params), |
|
$this->buildWhere($query->where, $params), |
|
$this->buildGroupBy($query->groupBy), |
|
$this->buildHaving($query->having, $params), |
|
$this->buildUnion($query->union, $params), |
|
$this->buildOrderBy($query->orderBy), |
|
//$this->buildLimit($query->limit, $query->offset), |
|
]; |
|
//var_dump( [implode($this->separator, array_filter($clauses)), $params]);exit; |
|
$this->sql = implode($this->separator, array_filter($clauses)); |
|
|
|
if (!is_null($query->limit) && !is_null($query->offset)) { |
|
$this->sql = $this->buildLimit($query->limit, $query->offset); |
|
} |
|
return [$this->sql, $params]; |
|
//return [implode($this->separator, array_filter($clauses)), $params]; |
|
} |
|
|
|
public function buildLimit($limit, $offset) { |
|
//var_dump($limit >= 0); |
|
//var_dump($offset);exit; |
|
//var_dump($limit, $offset); |
|
if (($limit < 0) && ($offset < 0)) { |
|
return $this->sql; |
|
} |
|
$filters = array(); |
|
if ($offset > 0) { |
|
$filters[] = 'rowNumId > ' . (int) $offset; |
|
} |
|
|
|
if ($limit >= 0) { |
|
$filters[] = 'rownum <= ' . (int) $limit; |
|
} |
|
|
|
if (count($filters) > 0) { |
|
$filter = implode(' and ', $filters); |
|
$filter = " WHERE " . $filter; |
|
} else { |
|
$filter = ''; |
|
} |
|
|
|
$sql = <<<EOD |
|
WITH USER_SQL AS ({$this->sql}), |
|
PAGINATION AS (SELECT USER_SQL.*, rownum as rowNumId FROM USER_SQL) |
|
SELECT * |
|
FROM PAGINATION |
|
{$filter} |
|
EOD; |
|
return $sql; |
|
} |
|
|
|
}
|
|
|