本文主要探讨,客户端如何通过TCP通信,根据分页信息从服务器获取到相关数据
通常情况下,数据可能很多,比如几千或者几万条,并不适合一次性从服务器获取。
我们只从服务器获取当前页的数据 和数据库中记录总数以便我们可以在客户端计算出页数 ,当用户点击“上一页”或者“下一页”时,再获取相应页的数据
如下图:
双击上图中的某一项,再打开详细页面,如下图:
下面我们从头开始创建一个分页显示的Demo
通信框架采用来自英国开源的networkcomms2.3.1版本
数据库为sql2005
第一步,在数据库中建表
Create Table PlDocs(ID int identity(1000,1) primary key,Title nvarchar(200),Description nvarchar(500))
ID 是流水号 主键
Title 公文名称
Description 公文的详细描述
第二步:打开 vs 2010 创建工程文件
为了简单,基于上一篇文章 创建的工程文件继续
添加2个新类库
第三步:打开CodeSmith模板 创建相关的“存储过程”,数据层代码 逻辑层代码 模板从此文中下载
(1):第一个模板的生成的存储过程如下:
存储过程
大家可以看到上面自动生成的存储过程中,包含分页存储过程,就是这一个,后面我们会用到
CREATE PROCEDURE [dbo].PlDocs_SelectPage-- Author: msdc-- Created: 2015-2-28-- Last Modified: 2015-2-28@PageNumber int,@PageSize intASDECLARE @PageLowerBound intDECLARE @PageUpperBound intSET @PageLowerBound = (@PageSize * @PageNumber) - @PageSizeSET @PageUpperBound = @PageLowerBound + @PageSize + 1CREATE TABLE #PageIndex ( IndexID int IDENTITY (1, 1) NOT NULL,ID Int)BEGININSERT INTO #PageIndex ( ID)SELECT [ID] FROM [dbo].[PlDocs] -- WHERE-- ORDER BYENDSELECT t1.* FROM [dbo].[PlDocs] t1JOIN #PageIndex t2ON t1.[ID] = t2.[ID] WHERE t2.IndexID > @PageLowerBound AND t2.IndexID < @PageUpperBound ORDER BY t2.IndexIDDROP TABLE #PageIndexGOSET ANSI_NULLS OFF GOSET QUOTED_IDENTIFIER OFF GO
PageNumber 是第几页
PageSize 是每页显示多少条
(2):继续使用模板生成数据层 (生成的数据层代码 与第一步生成的存储过程 是自动关联的)(命名空间需要手动改一下)
数据层代码
数据层还用到了基本SQL 操作类,每次使用复制过来即可
(3):继续使用模板生成逻辑层代码
逻辑层中有2个类:(命名空间需要手动改一下)
实体类
操作类
至此,模板的工作完成,工程文件目前的状态如下:
在逻辑层中添加2个契约类,用于客户端与服务器端的通信 (序列化方法使用protobuf.net)
PageInfoContract 当前是第几页 每页显示多少条
根据信息获取到的公文
客户端相关代码:
客户端相关代码
服务器端相关代码:
NetworkComms.AppendGlobalIncomingPacketHandler("GetAllDocs", IncomingGetAllDocs);
IncomingGetAllDocs
数据操作类和存储过程,本Demo中不需要再修改。
如果您的使用环境中,增加了关键字或者类别的设定,数据操作类和存储过程需要进行相关的修改.
到这里 示例就完成了 我们看一下界面: