时间:2016-02-16 02:55 来源: 我爱IT技术网 作者:佚名
欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【asp.net中用DataReader高效率分页】,下面是详细的讲解!
asp.net中用DataReader高效率分页
/// <summary>
/// PageList for DataReader
/// </summary>
/// <param name="connectionString"></param>
/// <param name="sql"></param>
/// <param name="pageSize"></param>
/// <param name="curPage"></param>
/// <param name="pageCount"></param>
/// <param name="count"></param>
/// <param name="cmdParms"></param>
/// <returns></returns>
public DataTable PageListReader(string connectionString, string sql, int pageSize, int curPage, out int pageCount, out int count, params DbParameter[] cmdParms)
{
int first=0;
int last=0;
int fieldCount=0;
using (SqlConnection conn=new SqlConnection(connectionString))
{
SqlCommand cmd=conn.CreateCommand();
PrepareCommand(cmd, conn, null, CommandType.Text, sql, cmdParms);
SqlDataReader reader=cmd.ExecuteReader(CommandBehavior.CloseConnection);
DataTable dt=new DataTable();
fieldCount=reader.FieldCount;
for (int i=0; i < fieldCount; i++)
{
DataColumn col=new DataColumn();
col.ColumnName=reader.GetName(i);
col.DataType=reader.GetFieldType(i);
dt.Columns.Add(col);
}
count=0;
first=(curPage - 1) * pageSize+1;
last=curPage * pageSize;
while (reader.Read())
{
count++;
if (count >=first && last >=count)
{
DataRow r=dt.NewRow();
for (int i=0; i < fieldCount; i++)
{
r[i]=reader[i];
}
dt.Rows.Add(r);
}
}
reader.Close();
pageCount=Convert.ToInt32(Math.Ceiling((double)count / (double)pageSize));
return dt;
}
}
关于asp.net中用DataReader高效率分页的用户互动如下:
相关问题:
答: >>详细
相关问题:
答: >>详细
相关问题:
答: >>详细
- 【asp】asp.net url重写浅谈-net-url重写
- 【DataSet】DataSet、DataTable、DataRow区别详解
- 【asp】asp.net 动态添加多个用户控件-net-动态添
- 【ASP】ASP.NET中内嵌页面代码的一个问题-NET-内
- 【As】Asp.net中的页面乱码的问题-sp--pn-ne-et
- 【增加记录】asp.net中获取新增加记录的ID Access
- 【创建】ASP.NET Web API教程 创建域模型的方法详
- 【Asp】Asp.net 页面调用javascript变量的值-net-
- 【ASP】ASP.NET 5升级后如何删除旧版本的DNX-NET5
- 【404页面】ASP.NET设置404页面返回302HTTP状态码
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
