2010-08-27 3 views
1

В основном я не могу получить бит разбиения на страницы, я сделал это до того, как изменил запрос на базу данных, и теперь я застрял.Проблема с разбивкой по кодовому сигналу

Моя модель выглядит следующим образом:

function get_properties($limit, $offset) { 
    $location = $this->session->userdata('location'); 
    $property_type = $this->session->userdata('property_type'); 
    if($property_type == 0) 
    { 
     $sql = "SELECT * FROM properties "; 
    } 
    // more queries here 
    $sql .= " LIMIT ".$limit.", ".$offset.";"; 
    $query = $this->db->query($sql); 
    if($query->num_rows() > 0) { 
     $this->session->set_userdata('num_rows', $query->num_rows()); 
     return $query->result_array();  
     return FALSE; 
     } 
    } 
} 

и мой контроллер выглядит следующим образом:

function results() { 
    $config['base_url'] = base_url().'/properties/results'; 
    $config['per_page'] = '3'; 
    $data['properties_results'] = $this->properties_model->get_properties($config['per_page'], $this->uri->segment(3)); 
    $config['total_rows'] = $this->session->userdata('num_rows'); 
    $this->pagination->initialize($config); 
    $config['full_tag_open']='<div id="pages">'; 
    $config['full_tag_close']='</div>'; 
    $data['links']=$this->pagination->create_links(); 
    $this->load->view('properties_results',$data); 
} 

пожалуйста, помогите ... его завинчивания!

+0

Не имеет отношения к вашему вопросу, но имейте в виду, что у вас может быть уязвимость при инъекции MySQL в коде при прямом изменении запроса. Вы должны использовать привязку параметров для этого, CI поддерживает его. – Ferdy

ответ

1

Причина, по которой она не работает, заключается в том, что вы никогда не получите total_rows. Вы получаете TOTAL_ROWS через этот запрос, но он уже имеет смещение и предел:

$sql .= " LIMIT ".$limit.", ".$offset.";"; 
$query = $this->db->query($sql); 

Чтобы это исправить, необходимо добавить функцию в вашей модели:

function get_all_properties() 
{ 
    return $this->db->get('properties'); 
} 

Затем в контроллере, а из:

$config['total_rows'] = $this->session->userdata('num_rows'); 

Do:

$config['total_rows'] = $this->properties_model->get_all_properties()->num_rows(); 

Это должно исправить вашу разбивку на страницы. Помимо этого у вашего кода есть странные вещи. Например. return FALSE; в get_properties НИКОГДА не выполнит. И почему вы храните столько данных в сеансах. Это не обязательно и не очень хорошая идея, на мой взгляд.

+0

Его нормально, я исправил его, это было связано с возвратом итоговых строк. Данные в сеансах взяты из формы поиска, как еще я могу это сделать, чтобы передавать информацию со страницы на страницу через codeigniter? – Ashley

+0

Я написал учебник о Cdeigniter Pagination. Пожалуйста, посмотрите и дайте свои предложения https://www.cloudways.com/blog/pagination-in-codeigniter/ –