关于jquery.datatable插件从数据库动态读取数据-动态分页

24 篇文章 0 订阅
3 篇文章 0 订阅

在上篇随笔中所提到的数据插入方法,是将所有数据一次性读出并插入表格,只能针对数据量小的操作。

本篇随笔记录的是datatable插件服务器端分页读取数据的方法。

一、分页

分页的基本思想是根据datatable的页码及每页显示的行数,将数据从数据库分段提出,然后再填充到表格中,以达到分页的效果。

这里需要用到datatable插件的几个属性:

"sEcho":这个属性需要原封不动地传回给datatable,具体的作用我也不清楚,但是根据它值的变化情况来看,好像是一个操作次数的计数(之前我一直把它当做是pageindex来用,结果发现,不论我在datatable中是翻下一页还是翻上一页,它一直在增加。)

"iDisplayStart":这个属性,根据字面意思理解,就是每段数据开始的行数,比如第一页的数据就是从0开始计,那么它就是0,每页显示的行数是10,那么第二页的第一行的iDisplayStart就是10。

"iDisplayLength":这个属性就是每页显示的行数。

然后是数据库操作,只需要从数据库查询其中一段数据,然后输出出来,转成JSON格式,让datatable插件获取。在网上可以找到很多分页的方法,我选择了其中一种,使用row_number()的分页的存储过程。具体代码如下(根据sql创建存储过程模板):

复制代码
USE T_LOG
GO
/****** 对象:  StoredProcedure [dbo].[pagination]    脚本日期: 07/30/2013 09:37:03 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE procedure [dbo].[pagination] 
 ( 
     @pageIndex int,  --页索引 
     @pageSize int    --每页记录数 
 ) 
 as 
 begin 
    set nocount on; 
    declare @sql nvarchar(500) 
    set @sql='SELECT LOG_ID,USER_ID,TABLE_NAME
            FROM (
            SELECT t.*,ROW_NUMBER()OVER(ORDER BY     t.LOG_ID) AS rownum
            FROM   T_LOG t
            ) AS a
            WHERE rownum BETWEEN ('+str(@pageSize)+' * ('+str(@pageIndex)+' - 1)) + 1 AND '+str(@pageSize)+' * '+str(@pageIndex)+''

    execute(@sql)  
    set nocount off; 
end
复制代码

存储过程的两个参数,pageindex表示页索引即当前页码,我不懂datatable有没有这项属性,所以我是用计算的方法得来的,就是iDisplayStart/iDisplayLength+1。

pagesize可以直接从datatable获得。

服务端的代码,我创建了一个datasource.ashx文件,代码如下:

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Data.SqlClient;

namespace WebApplication1
{
    /// <summary>
    /// Handler1 的摘要说明
    /// </summary>
    public class Handler1 : IHttpHandler
    {
        
        public void ProcessRequest(HttpContext context)
        {
            string sEcho = context.Request.Form["sEcho"];
            int iDisplayStart;
            int iDisplayLength;
            int.TryParse(context.Request.Form["iDisplayStart"], out iDisplayStart);
            int.TryParse(context.Request.Form["iDisplayLength"], out iDisplayLength);
            int pageindex = iDisplayStart / iDisplayLength + 1;
            int count = getcount();
            //DataTableToObjects类中的DataTableToJson()方法用来将数据转成json数据格式
            string json = DataTableToObjects.DataTableToJson(int.Parse(sEcho),count,getJson(pageindex.ToString(),iDisplayLength.ToString()),false);
            context.Response.Write(json);
            
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }

        public static DataTable getJson(string pageindex, string iDisplayLength)   //执行存储过程,提出数据
        {
            string constr = "此处填写数据库连接字段"; 
            using (SqlConnection conn = new SqlConnection(constr))
            {
                string sqlstr = "DECLARE @pageIndex int " +
                                "DECLARE @pageSize int " +
                                "EXECUTE pagination " + pageindex + "," + iDisplayLength;             
                DataSet ds = new DataSet();
                SqlDataAdapter da = new SqlDataAdapter();
                da.SelectCommand = new SqlCommand(sqlstr, conn);
                da.Fill(ds);
                DataTable dt = ds.Tables[0];
                return dt;
            }
            
        }
        public int getcount()     //获取数据总行数,iTotalRecords参数需要
        {
            string constr = "此处填写数据库连接字段"; 
            string countstr = "select count(1) from T_LOG";
            using (SqlConnection conn = new SqlConnection(constr))
            {
                conn.Open();
                SqlCommand com = new SqlCommand(countstr, conn);
                object obj = com.ExecuteScalar();
                conn.Close();
                return int.Parse(obj.ToString());
                
            }
        }     
    }
}
复制代码

DataTableToObjects类的代码如下:

复制代码
using System;
using System.Collections.Generic;
using System.Web;
using System.Text;
using System.Data;

namespace WebApplication1
{
    public class DataTableToObjects
    {
        public static string DataTableToJson(int sEcho, int totalRow, DataTable dt, bool dt_dispose)
        {
            StringBuilder json = new StringBuilder();
            json.Append("{\"sEcho\":" + sEcho.ToString() + ",");
            json.Append("\"iTotalRecords\":" + totalRow.ToString() + ",");
            json.Append("\"iTotalDisplayRecords\":" + totalRow.ToString() + ",");
            json.Append("\"aaData\":[");
            //json.AppendFormat("{\"sEcho\":{0},\n \"iTotalRecords\":{1},\n \"iTotalDisplayRecords\": {2},\n \"aaData\":[", sEcho, totalRow, totalRow);
            
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    json.Append("{");
                    for (int j = 0; j < dt.Columns.Count; j++)
                    {
                        json.Append("\"");
                        json.Append(dt.Columns[j].ColumnName);
                        json.Append("\":\"");
                        json.Append(dt.Rows[i][j].ToString());
                        json.Append("\",");
                    }
                    json.Remove(json.Length - 1, 1);
                    json.Append("},");
                }
                json.Remove(json.Length - 1, 1);
                json.Append("]}");
       
            return json.ToString();
        }

    }  

}
复制代码

需要注意的一点:iTotalRecords与iTotalDisplayRecords是两个不同的值,是改变分页栏显示用的参数,这里因为没有考虑数据过滤功能,所以都设置成数据的总的行数。

然后是客户端的代码,与之前的差不多:

复制代码
<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title></title>
    <link rel="stylesheet" type="text/css" href="Styles/jquery.dataTables.css"/>
    <script type="text/javascript" charset="utf8" src="Scripts/jquery.js"></script>
    <script type="text/javascript" charset="utf8" src="Scripts/jquery.dataTables.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $("#example").dataTable({
                "bLengthChange": false,
                "bFilter": false,
                "bSort": false,
                "iDisplayLength": 10,
                //"sPaginationType": "full_numbers",            
                "bProcessing": true,
                "bServerSide": true,
                "sAjaxSource": "Handler1.ashx",
                "sServerMethod": "POST",
                "aoColumns": [
                        { "mData": "LOG_ID" },
                        { "mData": "USER_ID" },
                        { "mData": "TABLE_NAME" }
                    ]
                //"fnServerParams": function (aoData) {
                //    aoData.push({ "name": "name1", "value": "value1" });
                //    aoData.push({ "name": "name2", "value": "value2" });
                //}
            });
        });
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <table id="example" width="100%" border="0" cellspacing="0" cellpadding="0">
      <thead>
        <tr>
          <td>LOG_ID</td>
          <td>USER_ID</td>
          <td>TABLE_NAME</td>
        </tr>
      </thead>
    </table>
    </form>
    
</body>
</html>
复制代码

因为测试,所以我只提取了表中的三个字段,并且关闭了数据过滤及排序功能,其中,"bLengthChange"可以设置成true,因为服务端会获取datatable的iDisplayLenth参数,即使每页显示数变化,数据也可以正常获取。

这样就实现了jquery.datatable插件的服务端分页获取数据。

先记录到这里,搜索及排序功能下次再说。

文章转载自:http://www.cnblogs.com/xuq23/p/3224477.html

谢谢博主分享。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
jquery.datatable是一款常用的前端表格插件,它支持前端和后端分页两种方式。在后端分页的情况下,数据请求和处理都在服务器端完成,前端只需要展示和呈现数据。 在使用jquery.datatable进行后端分页时,我们需要进行以下步骤: 1.准备后端接口:需要在服务器端提供一个接口来处理数据请求。这个接口需要接受一些参数,例如当前页码、每页显示数量等。接口会根据这些参数查询数据库,并返回相应的数据结果。 2.前端配置datatable插件:在前端页面中,需要引入jquery.datatable的相应脚本文件,并配置datatable的参数。其中,重要的参数包括ajax配置项,用于指定后端接口的URL,以及服务器端接口需要的参数。 3.发送数据请求:当用户操作表格进行翻页或者其他操作时,jquery.datatable会根据配置的ajax参数自动发送数据请求到后端接口。请求参数中包含当前页码、每页显示数量等信息。 4.服务器处理请求:后端接口接收到数据请求后,根据请求参数进行相应的查询和处理操作。可以使用数据库查询语言等方式查询数据库,并返回结果给前端。 5.前端展示数据:jquery.datatable会自动根据后端返回的数据结果,生成对应的表格展示。同时,它还提供了丰富的功能和样式配置选项,使得表格的展示更加灵活和美观。 总结来说,使用jquery.datatable进行后端分页需要准备后端接口,配置前端datatable,并进行数据请求和处理。这样就能够实现在前端页面展示由后端数据查询而来的分页表格。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值