2010-08-27 81 views
1

我基本上無法獲得分頁位的工作,我做了之前,我改變了我的數據庫查詢,現在我卡住了。Codeigniter分頁問題

我的模型看起來像:

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 2010-08-30 19:39:50

回答

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

務必:

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

這應該修復您的分頁。除此之外,你的代碼有一些奇怪的東西。例如。 return FALSE;get_properties永遠不會執行。你爲什麼在會話中存儲這麼多的數據。在我看來,這不是必要的,也不是一個好主意。

+0

它確定我已修復它,這是與返回的總行。 會話中的數據來自搜索表單,我還可以如何做到這一點通過codeigniter從頁面到頁面傳遞信息? – Ashley 2010-08-27 13:54:03

+0

我寫過關於Cdeigniter分頁的教程。請看看並提出建議https://www.cloudways.com/blog/pagination-in-codeigniter/ – 2017-11-24 14:09:17