SqlServer分页存储过程(多表查询,多条件排序),Repeater控件呈现数据以及分页
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。存储过程优点:
1、重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。
2、减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。
3、安全性。参数化的存储过程可以防止SQL注入式攻击。
本文演示使用SqlServer存储过程(多表查询,多条件排序),SqlServer数据访问辅助类、Repeater控件呈现数据以及分页,自定义服务器控件开发,效果如下图1所示。在随附的代码下载中提供了完整的源代码。

图1 效果图
演示程序结构
创建演示程序,我在Visual Studio 2013 选择新建两个项目,第一,C#空白网站项目将该网站命名为TestWeb,添加相关文件夹、CSS文件,JS文件;第二,C#类库命名为TestRun.WebPagerControls,封装分页UI,分页事件。图2 显示了演示程序的整体结构。

图2 程序的整体结构
使用SqlServer2008,创建演示数据TestRunDB,添加数据表dbo.tb_Category(产品分类),dbo.tb_Product(产品信息)以及演示数据、分页存储过程dbo.PROC_QueryByPager。图3 显示演示数据库内容

图3 演示数据库内容
程序执行
显示页面Default.aspx
在Default.aspx显示页面使用两个控件呈现数据以及分页,
第一,Repeater数据控件
该控件优点:是一个完全的开发性控件,可以自如的显示用户自定义的显示方式,但是缺点:不支持分页、排序、编辑,仅提供重复模板内容。
第二,自定义服务器分页控件
该控件的优点允许完全控制所生成的 HTML,提供更好的设计时支持。可以通过如下语句使用自定义服务器控件,
注册控件<%@ Register Assembly="TestRun.WebPagerControls" Namespace="TestRun.WebPagerControls" TagPrefix="cc1" %>
使用控件<cc1:WebPager ID="UPager1" runat="server" PagerStyle="NextPrev" ControlToPaginate="rptData" PageSize="5" OnPageIndexChanged="UPager1_PageIndexChanged" />
显示页面Defualt.aspx代码,如下图4所示

图4 显示页面代码
显示页面Defualt.aspx.cs定义了两个方法,第一BindData方法用于获取数据,第二UPager1_PageIndexChanged是分页事件。Defualt.aspx.cs定义代码如下图5所示

图5 显示页面Defualt.aspx.cs代码
自定义服务器分页控件的定义
自定义服务器控件的代码如下图6所示,由于定义的代码比较多,这里就不全部展开了


图6 显示Pager.cs代码
执行分页存储过程
在QueryProvider.cs文件定义执行分页存储过程,使用SqlHelper辅助类来执行访问数据库。SqlHelper用于简化你重复的去写那些数据库连(SqlConnection),SqlCommand,SqlDataReader等等。SqlHelper 封装过后通常是只需要给方法传入一些参数如数据库连接字符串,SQL参数等,就可以访问数据库了,很方便。代码如下图7所示

图7 显示QueryProvider.cs代码
分页存储过程的定义
在TestRunDB数据库中定义的分页存储过程如下图8所示


图8 显示分页存储过程的定义语句
结束
本文演示使用SqlServer存储过程(多表查询,多条件排序),SqlServer数据访问辅助类、Repeater控件呈现数据以及分页,自定义服务器控件开发,效果如下图1所示。在随附的代码下载中提供了完整的源代码。完整的源代码下载链接
SqlServer分页存储过程(多表查询,多条件排序),Repeater控件呈现数据以及分页的更多相关文章
- Repeater控件使用(含删除,分页功能)
Repeater控件使用(含删除,分页功能) 摘自:http://www.cnblogs.com/alanliu/archive/2008/02/25/914779.html 前臺代碼 <%@ ...
- SqlServer:SqlServer(存储过程动态表查询(取消返回值),事务处理,批量还原sqlserver备份,强制删除被占用的数据库)
1.存储过程动态表查询 USE [NETWORKING_AUDIT] GO /****** Object: StoredProcedure [dbo].[impConfigInfo] Script D ...
- 使用Sql分页方法给Repeater控件分页的方法
页面代码 <div class="bookList"> <asp:Repeater ID="rpBooks" runat="serv ...
- repeater控件实现分页
repeater控件实现排序的方法,今天我再向大家介绍repeater控件如何实现分页的效果. 分页分为真分页和假分页. 真分页:控件上一页需要显示多少数据,就从数据库取出并绑定多少数据,每次换页时都 ...
- asp.net动态网站repeater控件使用及分页操作介绍
asp.net动态网站repeater控件使用及分页操作介绍 1.简单介绍 Repeater 控件是一个容器控件,可用于从网页的任何可用数据中创建自定义列表.Repeater 控件没有自己内置的呈现功 ...
- repeater控件自定义Url分页带参数
repeater控件的效果图如下: 该页面实现的功能如下: 1.上下分页,(也可以带首页和末页,我只是禁掉了没用) 2.根据用户输入的指定分页索引进行跳转 3.根据筛选数据的参数进行URL分页的参数传 ...
- Repeater控件的分页实现
本文讲解Repeater控件与PagedDataSource相结合实现其分页功能.PagedDataSource 类封装那些允许数据源控件(如 DataGrid.GridView)执行分页操作的属性. ...
- 使用Repeater控件实现三层嵌套以及分页效果
PS: 第一次用Repeater控件 记录一下 请忽略我的命名不规范 请忽略我的最终效果图(太丑了) 需要用到的朋友可以自行调整的漂亮点 ====================最终效果图===== ...
- 使用ScriptX控件实现IE浏览器分页打印功能
之前讲过js调用ie浏览器自带打印的用法,今天讲使用插件的方式.浏览器自带打印不能控制页边距.页眉页脚等选项,尤其是如果分页打印的话,无法自动将前一页标题带到本页,所以不适用多页打印的功能.使用Scr ...
随机推荐
- P1016 高精度除法
题目描述 给你两个很大的正整数A和B,你需要计算A除以B的商和余数. 输入格式 输入一行包含两个正整数A和B,以一个空格分隔(A和B的位数都不超过 \(10^5\)) 输出格式 输出一行包含两个整数, ...
- linux 内核定时器
无论何时你需要调度一个动作以后发生, 而不阻塞当前进程直到到时, 内核定时器是给你 的工具. 这些定时器用来调度一个函数在将来一个特定的时间执行, 基于时钟嘀哒, 并且 可用作各类任务; 例如, 当硬 ...
- 苹果笔记本修改pycharm for mac 修改字体大小
实在是隐藏的太深了,无语
- Visio高级应用部件
标注与公式的应用: 插入标注 怎么让标注与图形建立关联:拖动标注的时候坐下角会出现黄色的点 把标准拖动到形状边的时候让黄点进入形状就是建立了关联 然后标注就会随着形状的移动而移动 而且复制和删除也都是 ...
- nor flash之频率限制
背景 支持一款nor flash时,出于性能考虑,一般会查看其nor支持的最高频率以及主控端spi控制器的最高频率,以选择一个合适的运行频率. 对于一款主控支持多款flash的情况,还得考虑好兼容性等 ...
- IDEA环境使用Git
推送到Github 在设置中登录github账户 点击OK 将项目交给Git管理 之后项目文件就会变成红色 添加文件到暂存区 点击Add之后,项目文件会变成绿色 添加文件到本地仓库 点击Commit ...
- eclipse中如何配置tomcat
1.打开eclipse上面的Windows选项,选择Preferences==>Server==>Runtime Environments==>Add 2.选择你电脑中安装的tomc ...
- 【一起学源码-微服务】Nexflix Eureka 源码十二:EurekaServer集群模式源码分析
前言 前情回顾 上一讲看了Eureka 注册中心的自我保护机制,以及里面提到的bug问题. 哈哈 转眼间都2020年了,这个系列的文章从12.17 一直写到现在,也是不容易哈,每天持续不断学习,输出博 ...
- selenium自动化之xpath定位*必会技能*
相信写过ui自动化,对xpath定位感觉会特别亲戚,那么下面给大家分享些我们常常在写脚本时易忽略的一些小细节和技巧.首先使用xpath定位时切忌 不要使用带有空格的属性 不要使用自动生成的id.cla ...
- Linux学习之路--常用命令
#ls 显示文件信息 #ll 显示文件(不包括隐藏文件)具体信息 等于 #ls -l #ll -a 显示所有文件(包括隐藏文件)具体信息 #ll -htr aa 显示最近修改的文件 h是易读的 ...