2

ユーザーが製品のタイトル、説明、または SKU を検索して最初の 20 件の結果を表示できる e コマース サイト用の CMS を CodeIgniter で作成しています。次に、次の 20 個の製品をロードする「さらに...」ボタンがあります。ただし、「more...」のクエリを取得して同じ量の結果を出力することはできません。私のモデルからの私の2つの関数は次のとおりです。

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

}

load more 関数では、ajax 呼び出しによって最後に表示された製品の ID が送信されるため、製品 ID で降順ソートを使用して、次の 20 の製品をより低い ID で取得できます。

何か案は?

4

2 に答える 2

2

このような「ページネーション」にアプローチしたいと思うでしょう。まず、機能は 1 つだけです。

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 に答える