微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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-1))

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; //设置命令为存储过程类型(即:指明我们执行的是一个存储过程)



                    rowCount = 0;
                    pageCount = 0;//这里随便给rowCount,pageCount赋个值,因为使用out传递参数的时候,在方法内部一定要给out参数赋值才能用它,但是虽然这里给它赋初值了,但是在执行存储过程中,存储过程又会给这两个参数赋值,并返还回来给我们,那个才是我们要值


                    sqlParameter[] parameters ={
                             new sqlParameter("@pageSize",pageSize),new sqlParameter("@currentpage",currentPage),new sqlParameter("@rowCount",rowCount),new sqlParameter("@pageCount",pageCount)
                                               
                                               };

                    //因为在存储过程中@rowCount 与@pageCount 是一个输出参数(output),而parameters这个数组里,第三,和第四个参数就是要用来替换掉这两个输出参数的,所以这里要将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;

                }
            }

        }
    }
}


在DAL文件夹中( 层中) 创建一个Aticel.cs类 产生一个list

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using LLsql.DAL;
using WebApplication1.Model;


namespace WebApplication1.DAL
{
    public class Aticel
    {
        public static List<Location> GetPagelistByPageIndex(int pageSize,int currentpage,out int pageCount)
        {

            DataTable dt= sqlHelper.ExecuteProcPagelist(pageSize,currentpage,out rowCount,out pageCount);

            var list = new List<Location>();// 声明一个泛型对象list
            if (dt != null && dt.Rows.Count > 0)
            {

                //将DataTable转换成一个list
                list = (from p in dt.AsEnumerable()  //(遍历DataTable)

                        select new Model.Location
                        {
                            Locid = p.Field<int>("Locid"),//将DateTable里的字段赋值给Location类中的属性
                            LocName = p.Field<string>("locName"),ParentId = p.Field<int>("parentId"),LocType = p.Field<short>("locType"),ElongCode = p.Field<string>("elongCode"),CityCode = p.Field<string>("CityCode"),BaiduPos = p.Field<string>("BaiduPos"),Versions = p.Field<short>("Version")

                        }).ToList(); 

            }
            return list; //将这个list返回回去
            
        }
    }
}


<3>

在API这个文件夹中创建一个GetPageData.ashx 页 (BLL层) 在这里调用ADL层里的 Aticel.cs类中的GetPagelistByPageIndex()方法获取一个list 并将这个list转换成一个Json格式字符串, 共AJAX 异步请求得到。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Script.Serialization;

namespace WebApplication1.API
{
    /// <summary>
    /// GetPageData 的摘要说明
    /// </summary>
    public class GetPageData : IHttpHandler
    {
        /// <summary>
        /// 根据用户传递的当前页的页码获取数据
        /// </summary>
        /// <param name="context"></param>
        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            int pageSize = 10; //设定页大小,每页显示10条数据
            int currentPage = Convert.ToInt32(context.Request.QueryString["currentPage"]); //设定当前页

            int rowCount = 0;  //作为out参数传递给方法,在方法里给rowCount赋值
            int pageCount = 0; //作为out参数传递给方法,在方法里给rowCount赋值

            string jsonData = null; 

            List<Model.Location> list= DAL.Aticel.GetPagelistByPageIndex(pageSize,currentPage,out pageCount);
            if (list != null && list.Count > 0)
            {

                //创建Json序列化器,将对象转换成一个Json格式的字符串
                JavaScriptSerializer jsz = new JavaScriptSerializer();

                jsonData = jsz.Serialize(list); //将一个list对象转换成json格式的字符串

                context.Response.Write(jsonData);

            }
            else
            {
                context.Response.Write("no");
            }
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}


前端页面 (将AJAX请求得到的数据展示也页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>使用AJAX分页</title>
    <script src="jquery-1.11.2.js" type="text/javascript"></script>
    <style type="text/css">
      table{ margin:80px 500px; }
      td{ width:50px; height:auto}
        
    </style>
    <script type="text/javascript">
        $(function () {
            $.get("API/GetPageData.ashx?currentPage=2",function (obj) { //假设当前页是第二页currentPage=2
                //debugger;

                var JsonData = $.parseJSON(obj);
                //alert(JsonData[0].Locid);
                //debugger;
                for (var i = 0; i < JsonData.length; i++) {
                    var data = "<tr><td >" + JsonData[i].Locid + "</td><td >" + JsonData[i].LocName + "</td><td >" + JsonData[i].ParentId + "</td><td >" + JsonData[i].LocType + "</td><td >" + JsonData[i].ElongCode + "</td><td >" + JsonData[i].CityCode + "</td><td >" + JsonData[i].BaiduPos + "</td><td >" + JsonData[i].Versions + "</td></tr>";
                    $("#t1").append(data);

                }

            })
        })
    </script>
</head>
<body>
 <table border="1" cellpadding="5" cellspacing="0" style="margin-top:100px;width:600px;" id="t1">
    <tr><td>编号</td><td >城市名</td><td >父ID</td><td >locType</td><td >elongCode</td><td >CityCode</td><td >BaiduPos</td><td >Version</td></tr>
 </table>

 </body>
</html>






原文地址:https://www.jb51.cc/ajax/163864.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐