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

<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

{

///

/// 获得连接数据库字符串

///

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;

}

}

}

}

}



总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值