我尝试做的是获取用户创建并保存到数据库中的所有笔记的数据库。
我创建了一个分页系统,该系统只显示他们创建的用户数据并在表格中显示。
问题:当我尝试显示结果时(只有用户的数据,而不是别人的数据),它显示完全正常。然而,底部的分页搞砸了。
很难解释。例如。我已将其设置为每页仅显示5个结果。但是,用户只有10行(注释)。所以它应该都适合第一页。该数据库也保存其他用户的数据,因此有超过50个。因此,不显示First < 1 2 > Last
之类的分页,而是显示First < 1 2 3 4 5...> Last
(额外的数字不需要,因为它已经在前两页显示所有用户的数据(注释)。)
当我点击5
或更高的其他数字时,它显示为空,仅显示该表的数据库标题,因为我将其设置为仅显示用户的数据,而不是任何人
我希望你明白我的意思。
我的控制器:
$uid = $this->session->userdata('uid'); //added on sat , feb 28
$this->load->library('pagination');
$this->load->library('table');
$config['base_url'] = 'http://localhost/dayone/profile/notes';
$config['total_rows'] = $this->db->get('notes')->num_rows();
$this->db->where('uid', $uid);
$this->db->order_by("time", "desc");
$config['per_page'] = 5;
$config['num_links'] = 2;
$this->pagination->initialize($config);
$data['records'] = $this->db->get('notes', $config['per_page'], $this->uri->segment(3));
$this->pagination->create_links();
$this->load->view('profile/includes/header');
$this->load->view('profile/view_all_entries', $data);
我的观点文件:
<?php include "includes/settings.php" ?>
<html>
<body>
<div class="container">
<h3 class="block-title block-title--simple"> Your <?php echo $site_title ?> Entries </h3>
<?php echo $this->table->generate($records); ?>
<?php echo $this->pagination->create_links(); ?>
</div>
</body>
</html>
答案 0 :(得分:1)
我修好了。这很简单。
只需像这样查询:$config['total_rows'] = $this->db->get_where('dayone_entries', array('uid' => $uid))->num_rows();