2

我正在 CodeIgniter 中为电子商务网站创建一个 CMS,用户可以在其中搜索产品标题、描述或 SKU,它将显示前 20 个结果。然后有一个“更多...”按钮,可以加载接下来的 20 个产品。但是,我无法获取“更多...”的查询以输出相同数量的结果。这是我的模型中的两个函数:

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 较低的产品。

有任何想法吗?

4

2 回答 2

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 个结果,使您的函数具有通用性和模块化。

于 2012-07-06T12:43:32.017 回答
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");
于 2012-07-06T11:41:37.477 回答