c#.net存储过程版本的分页
来源:互联网 发布:tracker视频分析软件 编辑:程序博客网 时间:2024/06/01 22:38
昨日编写了一个c#.net存储过程版本的分页,支持百万数据分页
因为有以前的CF、Javascript、Php及Asp的分页基本,昨天拿着C#.net顺心很多,其实也就是把CF中的代码直接复制粘贴进Vs.net中,编写了一个类也就OK了。
用起来挺顺心。调用方式大致如下:
protected void dataBind() {
int page = 1;
if (Request.QueryString["page"] != null){
page = Convert.ToInt32(Request["page"]);
}
if (Request.Form["page"] != null){
page = Convert.ToInt32(Request.Form["page"]);
}
int myPageSize = 20;
SqlConnection conn = new SqlConnection(dbTool.myConnStr);
SqlCommand cmd = new SqlCommand("p_page", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@Tables", SqlDbType.VarChar, 50);
cmd.Parameters["@Tables"].Value = "testTable";
cmd.Parameters.Add("@PrimaryKey", SqlDbType.VarChar, 50);
cmd.Parameters["@PrimaryKey"].Value = "id";
cmd.Parameters.Add("@Sort", SqlDbType.VarChar, 50);
cmd.Parameters["@Sort"].Value = "id asc";
cmd.Parameters.Add("@CurrentPage", SqlDbType.Int, 4);
cmd.Parameters["@CurrentPage"].Value = page;
cmd.Parameters.Add("@PageSize", SqlDbType.Int, 4);
cmd.Parameters["@PageSize"].Value = myPageSize;
cmd.Parameters.Add("@Fields", SqlDbType.VarChar, 50);
cmd.Parameters["@Fields"].Value = "id,username";
cmd.Parameters.Add("@Filter", SqlDbType.VarChar, 50);
cmd.Parameters["@Filter"].Value = "id>1000 and id<10000";
cmd.Parameters.Add("@Group", SqlDbType.VarChar, 50);
cmd.Parameters["@Group"].Value = "";
cmd.Parameters.Add("@TotalPage", SqlDbType.Int, 4);
cmd.Parameters["@TotalPage"].Direction = ParameterDirection.Output;
cmd.Parameters.Add("@TotalRecord", SqlDbType.Int, 4);
cmd.Parameters["@TotalRecord"].Direction = ParameterDirection.ReturnValue;
conn.Open();
//先取得返回值
cmd.ExecuteNonQuery();
int totalPage, totalRecord;
totalPage = Convert.ToInt32(cmd.Parameters["@TotalPage"].Value);
totalRecord = Convert.ToInt32(cmd.Parameters["@totalRecord"].Value);
//再取得返回记录集
SqlDataReader sdr = cmd.ExecuteReader();
GridView1.DataSource = sdr;
GridView1.DataBind();
cmd.Dispose();
conn.Dispose();
tools mytool = new tools(Response, Request);
/*
* 功能:PageLink显示分页导航
* totalCount:总记录数
* totalPage:总页数
* Page:页码
* PerPageSize:每页显示记录数
* GroupSizes:每组分页显示的页码数
* PageArgu:分页参数
* ShowGoto:是否显示跳转
*/
lblPageLink.Text = mytool.PageLink(totalRecord, totalPage, page, myPageSize, 3, "page",true);
mytool.Dispose();
}
- c#.net存储过程版本的分页
- c#.net存储过程版本的分页(转)
- 一个c#.net存储过程版本的分页,支持百万数据分页
- 一个c#.net存储过程版本的分页,支持百万数据分页
- Asp.net(C#)基于存储过程分页的完整解决方案
- asp.net 分页控件与执行分页的存储过程
- ASP.NET(c#)GRIDVIEW+SQL存储过程分页
- Asp.Net (C#)如何进行Oracle数据库分页(存储过程)
- ASP.NET(c#)GRIDVIEW+SQL存储过程分页
- MSSQL根据表名动态分页的存储过程以及C#.net调用使用
- Asp.net 分页存储过程
- Asp.Net分页存储过程
- ASP.NET存储过程分页
- ASP.NET存储过程分页
- Asp.Net分页存储过程
- .net调用分页存储过程
- Asp.Net分页存储过程
- asp.net 分页存储过程
- Categories of Quality
- testing types
- 优秀的博客 downmoon
- 一个快要毕业的大学生的问题,如何成为一个程序员。
- 钩子函数
- c#.net存储过程版本的分页
- Java学习--过程篇
- Hacking Windows CE: 如何从线程ID获取线程名称
- 通过就餐礼仪可判断人的性格
- 直线生成算法
- 团队开发中,如何处理一个站点不同Web应用通用Session
- 上拉电阻和下拉电阻
- C# generic的初步接触
- 数据加密-无聊杂谈