0

stackoverflow上有这么多分页问题,​​但我用codeigniter看不到它,所以就这样吧。

我们需要看看这些图片 在此处输入图像描述

和这里

在此处输入图像描述

和这里

在此处输入图像描述

我的桌子上有十条记录,链接失效了,这里是controller/index

$query = $this->m_kategorimaterial->get();  
    $config['base_url'] =  base_url().'index.php/c_kategorimaterial/index/';
    $config['total_rows'] = $query->num_rows();
    $config['per_page'] = 5; 
    $this->pagination->initialize($config);
    $data['rows'] = $query->result();
    $data['title'] = 'QB Kategori Material';
    $this->load->view('menu',$data);
    $this->load->view('v/vkategorimaterial');

这是模型

 $this->db->order_by('Kode_Kategori_Material_Jasa','DESC');
    $query = $this->db->get('ms_kategori_material');
    return $query;

为什么链接不起作用?我该如何解决?谢谢stackoverflow

4

2 回答 2

1

您在哪里调用数据收集查询中的偏移量?您需要为查询提供偏移量,以便它知道要获取哪些记录。

您还必须将 total_rows 更改为第二个查询,该查询查询整个表的总记录,因为您的新查询只返回一页的足够记录。

模型:

$this->db->order_by('Kode_Kategori_Material_Jasa','DESC');
$query = $this->db->get('ms_kategori_material', $limit, $offset);
return $query;

function getRecordCount() {

$query=$this->db->get('ms_kategori_material');
$result = $query->num_rows();
return $result;
}

控制器:

$config['base_url'] =  base_url().'index.php/c_kategorimaterial/index/';
$config['total_rows'] = $query->num_rows();
$config['per_page'] = 5; 
$this->pagination->initialize($config);
$query = $this->m_kategorimaterial->get($config['per_page'],$this->uri->segment(3));
$data['rows'] = $this->m_kategorimaterial->getRecordCount();
$data['title'] = 'QB Kategori Material';
$this->load->view('menu',$data);
$this->load->view('v/vkategorimaterial');

似乎你可以对这里发生的事情做一个小小的解释。要进行分页 CI(或任何应用程序)至少需要 3 个变量。

限制 - 我应该每页显示多少条记录,因此我的查询返回多少条记录。

偏移量 - 查询从哪里开始请求记录,对于 CI,这是 uri 段的来源,它部分由限制控制,因此如果您有 8 作为限制(每页),则每个查询都会将偏移量增加 8。所以第 1 页在数据库中查询从开头开始的前 8 条记录,第二页从第 9 条记录开始的前 8 条记录,依此类推。

总记录 - 这是整个表中查询的总匹配记录。这就是应用程序如何确定总共有多少页以及是否需要第二页。此查询没有限制或偏移,因为您想要所有匹配的记录而不是部分返回。

数据的实际分页由数据库查询执行。CI 只是告诉数据库它需要哪些记录。

希望这有助于澄清事情。

于 2012-10-25T12:36:03.470 回答
1

尝试设置

$config['uri_segment'] = 3;

这是您需要的完整信息 > http://codeigniter.com/user_guide/libraries/pagination.html

于 2012-10-25T12:17:51.063 回答