2012-07-06 74 views
2

我在CodeIgniter中爲電子商務網站創建一個CMS,用戶可以在其中搜索產品標題,說明或SKU並顯示前20個結果。然後有一個「更多...」按鈕,可以加載下20個產品。但是,我不能獲得「更多...」的查詢以輸出相同數量的結果。下面是我從我的模型2個功能:'加載更多'sql功能不加載正確的產品

public function searchProducts($searchText) 
{ 

    $this->db->select("prod_id, prod_sku, prod_title, prod_desc, prod_main_image"); 
    $this->db->where("prod_sku LIKE '%{$searchText}%'"); 
    $this->db->or_where("prod_title LIKE '%{$searchText}%'"); 
    $this->db->or_where("prod_desc LIKE '%{$searchText}%'"); 
    $this->db->order_by("prod_id", "desc"); 
    $query = $this->db->get("products", 20); 

    return $this->checkSalesProducts($query->result()); 

} 

public function loadMoreSearchProducts($searchText, $id) 
{ 

    $this->db->select("prod_id, prod_sku, prod_title, prod_desc, prod_main_image"); 
    $this->db->where("(prod_sku LIKE '%{$searchText}%' OR prod_title LIKE '%{$searchText}%' OR prod_desc LIKE '%{$searchText}%') AND `prod_id` < {$id}"); 
    $this->db->order_by("prod_id", "desc"); 
    $query = $this->db->get("products", 20); 

    return $this->checkSalesProducts($query->result()); 

} 

在負載更多的功能,Ajax調用發送的最後一個產品的ID顯示,這樣我可以使用的產品ID降序排序,以獲得產品具有更低下一個20的ID。

任何想法?

回答

2

你會想辦法「分頁「就像這樣。首先只有一個功能。

public function searchProducts($searchText, $page = 0) 
{ 
    $this->db->select("prod_id, prod_sku, prod_title, prod_desc, prod_main_image") 
     ->where("prod_sku LIKE '%{$searchText}%'") 
     ->or_where("prod_title LIKE '%{$searchText}%'") 
     ->or_where("prod_desc LIKE '%{$searchText}%'") 
     ->order_by("prod_id", "desc") 
     ->limit(20, $page*20); 

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

    return $this->checkSalesProducts($query->result()); 
} 

這樣,您將在每個不同的頁面上加載下20個結果。有$page = 0將默認爲前20個結果,使您的功能通用和模塊化。

0

如果我正確理解你的問題,你需要設置loadMoreSearchProducts()偏移

$query = $this->db->get("products", 20, 20); 

編輯:

試試這個:

$this->db->where("(prod_sku LIKE '%{$searchText}%' OR prod_title LIKE '%{$searchText}%' OR prod_desc LIKE '%{$searchText}%') AND `prod_id` > {$id}"); 
$this->db->order_by("prod_id", "asc"); 
+0

我認爲有ID從最高到最低,並把「少於最後ID」部分在where子句應該這樣做? – 2012-07-06 12:20:06