在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
下面是存储过程(sqlserver2000下通过)
字串7
--最通用的分页存储过程 字串1
else begin --以下代码赋予了@strSQL以真正执行的SQL代码 set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from [' + @tblName +'] where [' + @fldName + ']' + @strTmp + '(['+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @fldName + '] from ['+ @tblName +']' + @strOrder + ') as tblTmp)'+ @strOrder if @strWhere != '' set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from ['+ @tblName +'] where [' + @fldName + ']' + @strTmp + '(['+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @fldName + '] from ['+ @tblName +'] where ' + @strWhere + ' ' + @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder end end exec ( @strSQL) GO 字串6 字串2
下面是C#的代码 字串7
字串7
this.docount = docount; } public PagerHelper(string tblname,bool docount, string strGetFields, string fldName,int pagesize, int pageindex,bool ordertype,string strwhere,string connectionString ) { this.tblName = tblname ; this.docount = docount ; this.strGetFields = strGetFields ; 字串3
this.fldName = fldName; this.pagesize = pagesize ; this.pageindex = pageindex; this.ordertype = ordertype ; this.strwhere = strwhere ; this.connectionString = connectionString ; } /**//// <summary> /// 得到记录集的构造函数 /// </summary> /// <param name="tblname"></param> 字串6 /// <param name="strwhere"></param> /// <param name="connectionString"></param> public PagerHelper(string tblname,string strwhere,string connectionString) { this.tblName = tblname; this.strwhere = strwhere ; this.docount = true; this.connectionString = connectionString ; } private string tblName; public string TblName 字串2 { get{return tblName;} set{tblName =value;} } private string strGetFields="*"; public string StrGetFields { get{return strGetFields ;} set{strGetFields =value;} } private string fldName=string.Empty; public string FldName { get{return fldName ;} 字串2 set{fldName =value;} } private int pagesize =10; public int PageSize { get{return pagesize ;} set{pagesize =value;} } private int pageindex =1; public int PageIndex { get{return pageindex ;} set{pageindex =value;} 字串8 } private bool docount=false; public bool DoCount { get{return docount ;} set{docount =value;} } private bool ordertype=false; public bool OrderType { get{return ordertype ;} set{ordertype =value;} } private string strwhere=string.Empty ; 字串5
public string StrWhere { get{return strwhere ;} set{strwhere =value;} } public IDataReader GetDataReader() { if(this.docount) { throw new ArgumentException("要返回记录集,DoCount属性一定为false"); } 字串8
// System.Web.HttpContext.Current.Response.Write(pageindex); return SqlHelper.ExecuteReader(connectionString,CommandType.StoredProcedure,"Pagination", new SqlParameter("@tblName",this.tblName), new SqlParameter("@strGetFields",this.strGetFields), new SqlParameter("@fldName",this.fldName), new SqlParameter("@PageSize",this.pagesize), new SqlParameter("@PageIndex",this.pageindex), 字串2 new SqlParameter("@doCount",this.docount), new SqlParameter("@OrderType",this.ordertype), new SqlParameter("@strWhere",this.strwhere) ); } public DataSet GetDataSet() { if(this.docount) { throw new ArgumentException("要返回记录集,DoCount属性一定为false"); 字串4
} return SqlHelper.ExecuteDataset(connectionString,CommandType.StoredProcedure,"Pagination", new SqlParameter("@tblName",this.tblName), new SqlParameter("@strGetFields",this.strGetFields), new SqlParameter("@fldName",this.fldName), new SqlParameter("@PageSize",this.pagesize), new SqlParameter("@PageIndex",this.pageindex), 字串6 new SqlParameter("@doCount",this.docount), new SqlParameter("@OrderType",this.ordertype), new SqlParameter("@strWhere",this.strwhere) ); } public int GetCount() { if(!this.docount) { throw new ArgumentException("要返回总数统计,DoCount属性一定为true"); 字串4 } return (int)SqlHelper.ExecuteScalar(connectionString,CommandType.StoredProcedure,"Pagination", new SqlParameter("@tblName",this.tblName), new SqlParameter("@strGetFields",this.strGetFields), new SqlParameter("@fldName",this.fldName), new SqlParameter("@PageSize",this.pagesize), new SqlParameter("@PageIndex",this.pageindex), 字串1 new SqlParameter("@doCount",this.docount), new SqlParameter("@OrderType",this.ordertype), new SqlParameter("@strWhere",this.strwhere) ); } } } |
请发表评论