jquery.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()
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)+' - )) + 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 + ;
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[];
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 = ; i < dt.Rows.Count; i++)
{
json.Append("{");
for (int j = ; 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 - , );
json.Append("},");
}
json.Remove(json.Length - , );
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": ,
//"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="" cellspacing="" cellpadding="">
<thead>
<tr>
<td>LOG_ID</td>
<td>USER_ID</td>
<td>TABLE_NAME</td>
</tr>
</thead>
</table>
</form> </body>
</html>
jquery.datatable插件从数据库读取数据的更多相关文章
- echarts通过ajax向服务器发送post请求,servlet从数据库读取数据并返回前端
1.echarts的官网上的demo,都是直接写死的随机数据,没有和数据库的交互,所以就自己写了一下,ok,我们开始一步一步走一遍整个流程吧. 就以官网最简单的那个小demo来做修改吧.官网上的小de ...
- 分享在MVC3.0中使用jQuery DataTable 插件
前不久在网络上看见一个很不错的jQuery的DataTable表格插件.后来发现在MVC中使用该插件的文章并不多.本文将介绍在MVC3.0如何使用该插件.在介绍该插件之前先简单介绍一下,推荐该插件的原 ...
- 10天学会phpWeChat——第三天:从数据库读取数据到视图
在第二天,我们创建了我们的第一个phpWeChat功能模块,但是比较简单.实际生产环境中,我们不可能有如此简单的需求.更多的情况是数据存储在MySql数据库中,我们开发功能模块的作用就是将这些数据从M ...
- C#实现从数据库读取数据到Excel
用第三方组件:NPOI来实现 先去官网:http://npoi.codeplex.com/下载需要引入dll(可以选择.net2.0或者.net4.0的dll),然后在网站中添加引用.使用 NPOI ...
- JMeter 参数化之利用JDBCConnectionConfiguration从数据库读取数据并关联变量
参数化之利用DBC Connection Configuration从数据库读取数据并关联变量 by:授客 QQ:1033553122 1. 下载mysql jar包 下载mysql jar包 ...
- Android打开数据库读取数据
打开数据库读取数据 private MyDatabaseHelper dbHelper; dbHelper=new MyDatabaseHelper(this,"List.db", ...
- JQuery DataTable插件
参考文件: http://blog.csdn.net/xuechongyang/article/details/8424897 http://blog.csdn.net/llhwin2010/arti ...
- SQL Server数据库读取数据的DateReader类及其相关类
之前学了几天的SQL Server,现在用C#代码连接数据库了. 需要使用C#代码连接数据库,读取数据. 涉及的类有: ConfigurationManage SqlConnection SqlCom ...
- Ecplise 中 加载JDBC 连接 Mysql 数据库读取数据
准备工作 首先下载 JDBC 驱动,下载地址https://www.mysql.com/products/connector/ 将压缩包解压得到文件 mysql-connector-java-5.1. ...
随机推荐
- 寒假222_Topcoder SRM648
序号1: A,随便模拟好了,最后30秒发现一个都比的错误,无奈输错格式. 2: B,问你出去两个点,以及所产生的边 问你:产生多的联通快 加答案加1. 数据小,随便写暴力 3: copy思路. 我们先 ...
- 转载淘宝UED响应十日谈
响应式十日谈:楔子 响应式十日谈第一日:使用 rem 设置文字大小
- 将HTML转成XHTML并清除一些无用的标签和属性
介绍 这是一个能帮你从HTML生成有效XHTML的经典库.它还提供对标签以及属性过滤的支持.你可以指定允许哪些标签和属性可在出现在输出中,而其他的标签过滤掉.你也可以使用这个库清理Microsoft ...
- 常用正则表达式(匹配URL/email/number)
var URL_REGEXP = /^(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/ ...
- zero to one:创业秘籍并不存在,因为任何创新都是新颖独特的,任何权威都不可能具体规定如何创新
彼得·蒂尔(Peter Thiel)的新作<从0到1>从预售开始就占据美国亚马逊排行榜第一名的位置,被一批创业家和企业家评为“迄今为止最好的商业书”.这是一本关于如何创建创新公司的书,主要 ...
- BZOJ1083: [SCOI2005]繁忙的都市
水题之王SP…这题就裸的最小生成树 /************************************************************** Problem: 1083 User ...
- login shell 和 non-login shell 的区别
介绍之前先思考一个问题:有时我们通过su命令切换用户后,却发现并没有进入该用户的shell环境.这是为什么? login shell:取得bash时需要完整的登录流程.就是说通过输入账号和密码登录系统 ...
- 一、Android NDK编程预备之Java jni简介
转自: http://www.eoeandroid.com/thread-264384-1-1.html 游戏开发 视频教程 博客 淘帖 论坛›eoe·Android应用开发区›Androi ...
- (一)初探HTML!
想自己动手做一个个人网站,因此,最近在自学PHP,主要看韩顺平老师的教学视频..将自己学习的点点滴滴记录在博客园,希望数月之后,自己可以熟练的运用PHP,也希望各位PHP高手们给予指点,不胜感激!! ...
- SQL server 为多个表添加新的列
作为一名.NET未入门的程序员,第一次发随笔. 前不久参与写的公司业务程序,目前这个程序的后期维护修复漏洞工作由我来负责.由于业务关系重大,每一步对程序代码的操作都非常谨慎,一旦操作失误,造成的损失和 ...