Codeigniter count_all_results с наличием - PullRequest
0 голосов
/ 04 января 2019

Я составил запрос, используя класс Query Builder от Codeigniter. В запросе используются псевдонимы и метод имения. Когда я вызываю метод count_all_results для этого запроса, возникает исключение. Просматривая журнал, я вижу, что в запросе исключены предложения «Имея». Есть ли способ сохранить эти пункты во время вызова count_all_results? Спасибо за вашу помощь.

РЕДАКТИРОВАТЬ: я сначала полагал, что проблема была основана на знаниях, а не на коде, и поэтому не разделял код, но вот он. Пожалуйста, дайте мне знать, если нужно больше.

Вот вызов модели в контроллере.

$where_array = array(
    $parent_key.' is not NULL' => null
);
$search_post = $request_data['search'];
if (isset($request_data['filter'])) {
    $filter_array = $request_data['filter'];
    foreach ($filter_array as $filter_pair) {
        if (isset($filter_pair['escape'])) {
            $where_array[$filter_pair['filterBy']] = null;
        } else {
            if ($filter_pair['filterBy'] == 'table3_id') {
            $where_array['table3.'.$filter_pair['filterBy']] = isset($filter_pair['filterId']) ?
                $filter_pair['filterId'] : null;
            } else {
                $where_array[$table.'.'.$filter_pair['filterBy']] = isset($filter_pair['filterId']) ?
                    $filter_pair['filterId'] : null;
            }
        }
    }
}
$like_array = array();
foreach ($request_data['columns'] as $key => $column) {
    if (!empty($column['search']['value'])) {
        $like_array[$column['data']] = $column['search']['value'];
    }
}
$totalFiltered = $this->$model_name->modelSearchCount($search, $where_array, $like_array);

Вот методы модели.

public function modelSearchCount($search, $where_array = null, $like_array = null)
{
    $this->joinLookups(null, $search);
    if ($where_array) {
        $this->db->where($where_array);
    }
    if ($like_array) {
        foreach($like_array as $key => $value) {
            $this->db->having($key." LIKE '%". $value. "%'");
        }
    }
    return $this->db->from($this->table)->count_all_results();
}

protected function joinLookups($display_config = null, $search = null)
{
    $select_array = null;
    $join_array = array();
    $search_column_array = $search ? array() : null;
    $i = 'a';

    $config = $display_config ? $display_config : $this->getIndexConfig();
    foreach ($config as $column) {
        if (array_key_exists($column['field'], $this->lookups)) {
            $guest_model_name = $this->lookups[$column['field']];
            $this->load->model($guest_model_name);
            $join_string =$this->table.'.'.$column['field'].'='.$i.'.'.
                $this->$guest_model_name->getKey();
            $guest_display = $this->$guest_model_name->getDisplay();
            if ($search) {
                $search_column_array[] = $i.'.'.$guest_display;
            }
            $join_array[$this->$guest_model_name->getTable().' as '.$i] = $join_string;
            $select_array[] = $i.'.'.
                $guest_display;
        } else {
            $select_array[] = $this->table.'.'.$column['field'];
            if ($search) {
                $search_column_array[] = $this->table.'.'.$column['field'];
            }
        }
        $i++;
    }
    $select_array[] = $this->table.'.'.$this->key;
    foreach ($join_array as $key => $value) {
        $this->db->join($key, $value, 'LEFT');
    }
    $this->db->join('table2', $this->table.'.table2_id=table2.table2_id', 'LEFT')
        ->join('table3', 'table2.table3_id=table3.table3_id', 'LEFT')
        ->join('table4', $this->table.'.table4_id=table4_id', 'LEFT')
        ->join('table5', 'table4.table5_id=table5.table5_id', 'LEFT');
    $this->db->select(implode($select_array, ', '));
    if ($search) {
        foreach (explode(' ', $search) as $term) {
            $this->db->group_start();
                $this->db->or_like($this->table.'.'.$this->key, $term);
            foreach ($search_column_array as $search_column) {
                $this->db->or_like($search_column, $term);
            }
            $this->db->group_end();
        }
    }
    $this->db->select('table2_date, '. $this->table.'.table2_id, table4_id, '. 'table5.table5_description');
}

Ответы [ 2 ]

0 голосов
/ 13 февраля 2019

Поскольку count_all_results() в основном будет запускать Select count(*) и не будет подсчитывать строки в вашем наборе результатов (в основном это делает запрос бесполезным для ваших целей), вы можете использовать другие методы Codeigniter для получения набора результатов и количества строк.

Попробуйте запустить запрос в переменную:

 $query = $this->db->get();

С тех пор вы можете делать практически все, что угодно. Помимо возврата результата с помощью $query->result();, вы можете получить количество строк в другой переменной с помощью:

 $rownum = $query->num_rows();

Затем вы можете вернуть это в свой контроллер или даже просто вернуть объект $query и затем запустить метод num_rows() на контроллере

0 голосов
/ 07 февраля 2019

Чтобы ответить на этот вопрос, count_all_results () преобразует исходный запрос, заменив выбранные вами значения SELECT COUNT (*) FROM table. столбец с псевдонимом не будет выбран, а предложение, имеющее имя, не будет распознавать столбец. Вот почему count_all_results () не работает с наличием.

...