首页 文章

使用Codeigniter分页查询结果

提问于
浏览
0

我是Codeigniter和PHP的新手,所以请耐心等待 .

我正在尝试使用codeigniter分页类来对查询返回的结果进行分页 . 下面的代码适用于不需要任何参数传递的静态查询 . 但是,当尝试将变量作为URL中的参数传递时,它似乎会崩溃,例如

localhost/index.php/termsbyletter/index/a

其中'a'是传递给控制器/模型的$ letter变量 .

PHP没有输出任何错误,并且查询按预期执行,模型中的record_count函数也是如此 . 结果是显示所有查询结果,但所有查询结果都在同一页面上,当单击分页链接时,它们保持不变 .

此外,在模型中,返回行计数是否比运行查询两次更有效?我在这里读到这是必要的,我没有任何成功试图以任何其他方式传递这个值 .

这是我的控制器:

<?php

class Termsbyletter extends CI_Controller
{
    public function __construct() {
        parent:: __construct();
        $this->load->helper("url");
        $this->load->model("terms_by_letter");
        $this->load->library("pagination");
    }

    public function index($letter) {

        $config = array();
        $config["base_url"] = base_url() . 'index.php/termsbyletter/index/' . $letter;
        $config["total_rows"] = $this->terms_by_letter->record_count($letter);
        $config["per_page"] = 3;
        $config["uri_segment"] = 5;

        $this->pagination->initialize($config);

        $page = ($this->uri->segment(5)) ? $this->uri->segment(5) : 0;
        $data["results"] = $this->terms_by_letter->term($config["per_page"], $page, $letter);
        echo $this->pagination->create_links();

        $this->load->view("/templates/header"); 
        $this->load->view("/terms/index", $data);  
        $this->load->view("/templates/footer"); 
       }
}

和模型:

class Terms_by_letter extends CI_Model
 {
    public function __construct() {
        parent::__construct();
            $this->load->database();
          }

    public function record_count($letter) {

          $query = $this->db->query("SELECT * FROM news WHERE LEFT(slug, 1) = '$letter'");
             return $query->num_rows();      
          }

    public function term($limit, $start, $letter) {

          $this->db->limit($limit, $start);
          $query = $this->db->query("SELECT * FROM news WHERE LEFT(slug, 1) = '$letter'");


              if ($query->num_rows() > 0) {
              foreach ($query->result() as $row) {
                 $data[] = $row;

            }
            return $data;
        }
        return false;


    }
 }

我正在使用这样的东西在视图中输出结果:

<?php
foreach($results as $data) {
    echo $data->slug "<br>";
}
?>
   <p><?php echo $links; ?></p>

1 回答

  • 1

    您正在尝试将活动记录与正常的CI查询混合在一起,但这不起作用 . 将查询更改为:

    $query = $this->db->query("SELECT * FROM news WHERE LEFT(slug, 1) = '$letter' LIMIT $start, $limit");
    

    无论是那个还是完全使用活动记录路线:

    $this->db->limit($limit, $start);
    $this->db->where('LEFT(slug,1)',$letter);
    $this->db->get('news');
    

    据我所知,无法通过单个查询返回所需的所有结果,控制器需要总记录来计算分页,然后它需要只选择一个页面的记录 .

    但是,您可以只编写一次查询并稍微更改参数 .

    public function term($limit, $start, $letter) {
    if($limit > 0)
    {
        $this->db->limit($limit, $start);
    }
    $this->db->where('LEFT(slug,1)',$letter);
    $this->db->get('news');
    

    然后在你的控制器中,你得到这样的计数:

    $config["total_rows"] = $this->terms_by_letter->term(0,0,$letter);
    

相关问题