Codeigniter - 使用分页,仅显示来自数据库的用户数据

时间:2015-03-01 02:47:44

标签: php mysql codeigniter pagination

我尝试做的是获取用户创建并保存到数据库中的所有笔记的数据库。

我创建了一个分页系统,该系统只显示他们创建的用户数据并在表格中显示。

问题:当我尝试显示结果时(只有用户的数据,而不是别人的数据),它显示完全正常。然而,底部的分页搞砸了。

很难解释。例如。我已将其设置为每页仅显示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>

1 个答案:

答案 0 :(得分:1)

我修好了。这很简单。

只需像这样查询:$config['total_rows'] = $this->db->get_where('dayone_entries', array('uid' => $uid))->num_rows();