Проблема нумерации кода - PullRequest
       21

Проблема нумерации кода

1 голос
/ 27 августа 2010

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

Моя модель выглядит так:

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);
} 

пожалуйста, помогите ... его облажались!

1 Ответ

1 голос
/ 27 августа 2010

Причина, по которой это не работает, в том, что вы никогда не получите 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 НИКОГДА не выполнится. И почему вы храните так много данных в сессиях. Это не обязательно и не очень хорошая идея, на мой взгляд.

...