AJAX分页 (内容涉及到 存储过程)

开发技术 作者: 2024-06-17 09:20:01
&lt1&gt首先我们在数据库(SQL Server)中声明定义存储过程use sales --指定数据库if(exists(select * from sys.objects where name=proc_location_Paging)) --如果这个proc_location_paging存储

<1>

首先我们在数据库(sql Server)中声明定义存储进程

use sales --指定数据库 if(exists(select * from sys.objects where name='proc_location_Paging')) --如果这个proc_location_paging存储进程存在则删除 drop proc proc_location_Paging go create proc proc_location_Paging --创建存储进程 ( @pageSize int,--页大小 @currentpage int,--当前页 @rowCount int output,--总行数(传出参数) @pageCount int output --总页数(传出参数) ) as begin select @rowCount= COUNT(locid) from location --给@rowCount赋值 select @pageCount= CEILING((count(locid)+0.0)/@pageSize) from location --给@pageCount赋值 select top (@pagesize)* from (select ROW_NUMBER() over(order by locid) as rowID,* from location) as t1 where rowID >(@pageSize*(@currentpage⑴)) end go ---------------------------------以上就表示这个存储进程已定义完了。 ---------------------------------以下是履行这个存储进程。我们可以看结果 declare @rowCount int,@pageCount int --先声明两个参数 --履行proc_location_Paging这个存储进程。@rowCount,@pageCount后面都有output 表示它们两是输出参数 exec proc_location_Paging 10,1,@rowCount output,@pageCount output select @rowCount,@pageCount --查询这两个参数的值


<2>

由于是直接访问数据库的,所以我们将下面这条方法写入到DAL层中,这里我将它写入到sqlHelper中

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Configuration; using System.Data.sqlClient; using System.Data; using System.Reflection; namespace LLsql.DAL { public class sqlHelper { /// <summary> /// 获得连接数据库字符串 /// </summary> private static string connStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString; public static DataTable ExecuteProcPageList(int pageSize,int currentPage,out int rowCount,out int pageCount) { using (sqlConnection conn = new sqlConnection(connStr)) { conn.Open(); using (sqlCommand cmd = conn.CreateCommand()) { cmd.CommandText = "proc_location_paging"; //存储进程的名字 cmd.CommandType = CommandType.StoredProcedure; //设置命令为存储进程类型(即:指明我们履行的是1个存储进程) rowCount = 0; pageCount = 0;//这里随意给rowCount,pageCount赋个值,由于使用out传递参数的时候,在方法内部1定要给out参数赋值才能用它,但是虽然这里给它赋初值了,但是在履行存储进程中,存储进程又会给这两个参数赋值,并返还回来给我们,那个才是我们要值 sqlParameter[] parameters ={ new sqlParameter("@pageSize",pageSize),new sqlParameter("@currentpage",currentPage),new sqlParameter("@rowCount",rowCount),new sqlParameter("@pageCount",pageCount) }; //由于在存储进程中@rowCount 与@pageCount 是1个输出参数(output),而parameters这个数组里,第3,和第4个参数就是要用来替换掉这两个输出参数的,所以这里要将parameters这个数组里的这两个参数设为输出参数。 parameters[2].Direction = ParameterDirection.Output; parameters[3].Direction = ParameterDirection.Output; cmd.Parameters.AddRange(parameters); //将参数传递给我们的cmd命令对象 DataTable dt = new DataTable(); using (sqlDataAdapter adapter = new sqlDataAdapter(cmd)) { adapter.Fill(dt);//到数据库去履行存储进程,并将结果填充到dt表中 } //等存储进程履行终了后,存储进程会把这两个输出参数传递出来。那末我们在这里来获得这两个返回参数。 rowCount = Convert.ToInt32(parameters[2].Value); pageCount = Convert.ToInt32(parameters[3].Value); return dt; } } } } }




原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_28572.html