zoukankan      html  css  js  c++  java
  • CI框架分页查询实现

    //进行数据分页
        /*
        @f_page 第一分页
        @s_page 第二分页
        @total_sql    总数sql
        @index_sql    列表sql
        @order        排序sql
        @select        查询sql
        */
        function get_page($f_page,$s_page="index",$total_sql,$index_sql,$order,$select='',$segment=4)
        {
            $this->CI = &get_instance();
            $page = $this->CI->uri->segment(4) ? : 1;
    
            $per_page =  10;
        
            $config['uri_segment'] = $segment; 
            $config['next_link'] = _('下一页');
            $config['prev_link'] = _('上一页');
            $config['first_link'] = _('首页');
            $config['last_link'] = _('尾页');
    
            if(!empty($select)){
            $offset = empty($this->CI->input->get('per_page')) == true ? 0 : $this->CI->input->get('per_page');
            $search_url =  preg_replace('/(&per_page=)(d*)/','', strstr($_SERVER["REQUEST_URI"], '?'));
            $config['base_url'] = '/management/'.$f_page.'/'.$s_page.'/'.$search_url;
            $config['page_query_string'] = true;
            }else
            {
                $offset = empty($this->CI->uri->segment(4)) == ture ? 0 :$this->CI->uri->segment(4);
                $config['base_url'] = '/management/'.$f_page.'/'.$s_page;
            }
            $sql=$total_sql;
            $total_db_result=$this->CI->db->query($sql)->result_array();
            $sql=$index_sql;
            
            if($select<>'')
                $sql.=' '.$select;
            $sql.=' '.$order;
            $sql.=" limit {$offset},{$per_page}";
            $db_result=$this->CI->db->query($sql)->result_array();
            
            $num_rows = $config['total_rows'] = $total_db_result[0]['total_count'];
            $this->CI->pagination->initialize($config);
            $page_link = $this->CI->pagination->create_links();
            $result=array('total'=>$total_db_result[0]['total_count'],'list'=>$db_result,'page'=>$page_link);
            return $result;
        }
  • 相关阅读:
    HDU
    P2458 [SDOI2006]保安站岗[树形dp]
    POJ 2155 Matrix[树状数组+差分]
    P1281 书的复制[二分]
    【清北学堂】广州OI学习游记
    P1736 创意吃鱼法[二维dp]
    P2161 [SHOI2009]会场预约[线段树/树状数组+二分/STL]
    P1972 [SDOI2009]HH的项链[离线+树状数组/主席树/分块/模拟]
    P1273 有线电视网[分组背包+树形dp]
    windows下安装MySQL
  • 原文地址:https://www.cnblogs.com/zhaobijin/p/5842780.html
Copyright © 2011-2022 走看看