1、ibatis.Net配置文件Common.xml
- <?xml version="1.0" encoding="utf-8" ?>
- <sqlMap namespace="Common" xmlns="http://ibatis.apache.org/mapping"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" >
- <alias>
- <typeAlias alias="PageCriteria" type="GM.Model.PageCriteria,GM.Model" />
- </alias>
- <parameterMaps>
- <parameterMap id="PageMap" class="PageCriteria">
- <parameter property="TableName" />
- <parameter property="PrimaryKey"/>
- <parameter property="Fields" />
- <parameter property="Condition" />
- <parameter property="CurrentPage" />
- <parameter property="PageSize" />
- <parameter property="Sort" />
- <parameter property="RecordCount" direction="Output" column="RecordCount"/>
- </parameterMap>
- </parameterMaps>
- <statements>
- <procedure id="GetPageData" parameterMap="PageMap" resultClass="Hashtable" >
- [dbo].[ProcGetPageData]
- </procedure>
- </statements>
- </sqlMap>
2、通用分页存储过程ProcGetPageData
- CREATE PROCEDURE [dbo].[ProcGetPageData]
- ( @TableName VARCHAR(1000), --表名,多表是请使用 tA a inner join tB b On a.AID = b.AID
- @PrimaryKey NVARCHAR(100), --主键,可以带表头 a.AID
- @Fields NVARCHAR(2000) = '*',--读取字段
- @Condition NVARCHAR(3000) = '',--Where条件
- @CurrentPage INT = 1, --开始页码
- @PageSize INT = 10, --页大小
- @Sort NVARCHAR(200) = '', --排序字段
- @RecordCount INT = 0 OUT
- )
- AS
- DECLARE @strWhere VARCHAR(2000)
- DECLARE @strsql NVARCHAR(3900)
- IF @Condition IS NOT NULL AND len(ltrim(rtrim(@Condition)))>0
- BEGIN
- SET @strWhere = ' WHERE ' + @Condition + ' '
- END
- ELSE
- BEGIN
- SET @strWhere = ''
- END
- IF (charindex(ltrim(rtrim(@PrimaryKey)),@Sort)=0)
- BEGIN
- IF(@Sort='')
- SET @Sort = @PrimaryKey + ' DESC '
- ELSE
- SET @Sort = @Sort+ ' , '+@PrimaryKey + ' DESC '
- END
- SET @strsql = 'SELECT @RecordCount = Count(1) FROM ' + @TableName + @strWhere
- EXECUTE sp_executesql @strsql ,N'@RecordCount INT output',@RecordCount OUTPUT
- IF @CurrentPage = 1 --第一页提高性能
- BEGIN
- SET @strsql = 'SELECT TOP ' + str(@PageSize) +' '+@Fields
- + ' FROM ' + @TableName + ' ' + @strWhere + ' ORDER BY '+ @Sort
- END
- ELSE
- BEGIN
- /* 执行动态sql*/
- DECLARE @START_ID NVARCHAR(50)
- DECLARE @END_ID NVARCHAR(50)
- SET @START_ID = CONVERT(NVARCHAR(50),(@CurrentPage - 1) * @PageSize + 1)
- SET @END_ID = CONVERT(NVARCHAR(50),@CurrentPage * @PageSize)
- SET @strsql = ' SELECT *
- FROM (SELECT ROW_NUMBER() OVER(ORDER BY '+@Sort+') AS rownum,
- '+@Fields+ '
- FROM '+@TableName + @strWhere +') AS XX
- WHERE rownum BETWEEN '+@START_ID+' AND ' +@END_ID +' ORDER BY XX.rownum ASC'
- END
- EXEC(@strsql)
- RETURN
- GO
3、分页相关信息类PageCriteria
- public class PageCriteria
- {
- private string _TableName;
- public string TableName
- {
- get { return _TableName; }
- set { _TableName = value; }
- }
- private string _Fileds = "*";
- public string Fields
- {
- get { return _Fileds; }
- set { _Fileds = value; }
- }
- private string _PrimaryKey = "ID";
- public string PrimaryKey
- {
- get { return _PrimaryKey; }
- set { _PrimaryKey = value; }
- }
- private int _PageSize = 10;
- public int PageSize
- {
- get{return _PageSize;}
- set{_PageSize = value;}
- }
- private int _CurrentPage = 1;
- public int CurrentPage
- {
- get { return _CurrentPage; }
- set { _CurrentPage = value; }
- }
- private string _Sort = string.Empty;
- public string Sort
- {
- get { return _Sort; }
- set { _Sort = value; }
- }
- private string _Condition = string.Empty;
- public string Condition
- {
- get { return _Condition; }
- set { _Condition = value; }
- }
- private int _RecordCount;
- public int RecordCount
- {
- get { return _RecordCount; }
- set { _RecordCount = value; }
- }
- }
3、调用存储过程方法返回数据
- public IList<Hashtable> GetListForPageSummary(PageCriteria criteria)
- {
- criteria.TableName ="Person";
- criteria.PrimaryKey = "Id";
- criteria.Fields = @"*";
- return Mapper.Instance().QueryForList<Hashtable>("GetPageData", criteria);
- }
注意:Condition不用再加where关键词了。
文章来源:http://www.lanhusoft.com/Article/97.html
最通用的ibatis.Net使用sql server存储过程返回分页数据的详细例子的更多相关文章
-
Sql Server 存储过程中查询数据无法使用 Union(All)
原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...
-
sql server中的分页数据查询
1.引言 今天在工作中遇到一个需要进行sql server分页数据查询的问题,但是分页数据查询的sql却忘记了,最终通过查询资料解决了该问题.现在把解决方法记下,以备查阅. 在这里需要感谢博客园的Ql ...
-
SQL Server 存储过程进行分页查询
CREATE PROCEDURE prcPageResult -- 获得某一页的数据 -- @currPage INT = 1 , --当前页页码 (即Top currPage) @showColum ...
-
sql server存储过程返回数据只有一个字符
SqlParameter[] param = { new SqlParameter("@shopId",shopId), new SqlParameter("@newSh ...
-
一条sql 执行查询列表 返回分页数据以及总数 totalCount
SELECT ID,Name,Age,Addr,Tel,COUNT(1) OVER() AS totalFROM dbo.Student WHERE Age>22 ORDER BY id DES ...
-
恢复SQL Server被误删除的数据(再扩展)
恢复SQL Server被误删除的数据(再扩展) 大家对本人之前的文章<恢复SQL Server被误删除的数据> 反应非常热烈,但是文章里的存储过程不能实现对备份出来的日志备份里所删数据的 ...
-
恢复SQL Server被误删除的数据
恢复SQL Server被误删除的数据 <恢复SQL Server被误删除的数据(再扩展)> 地址:http://www.cnblogs.com/lyhabc/p/4620764.html ...
-
初识 Sql Server存储过程
开篇语 之前的公司并未使用存储过程来做项目,所以小生对存储过程的调用.使用也是一知半解,刚好这家公司就大量用到了存储过程 这次做的功能,为了保持风格一致,也是需要使用存储过程来实现动态sql和数据分页 ...
-
sql server存储过程中SELECT 与 SET 对变量赋值的区别
SQL Server 中对已经定义的变量赋值的方式用两种,分别是 SET 和 SELECT. 对于这两种方式的区别,SQL Server 联机丛书中已经有详细的说明,但很多时候我们 并没有注意,其实这 ...
随机推荐
-
Android数据存储之Android 6.0运行时权限下文件存储的思考
前言: 在我们做App开发的过程中基本上都会用到文件存储,所以文件存储对于我们来说是相当熟悉了,不过自从Android 6.0发布之后,基于运行时权限机制访问外置sdcard是需要动态申请权限,所以以 ...
-
json转js对象
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
-
Maven in 5 Minutes(Windows)
这是根据官网的例子写的入门例子:http://maven.apache.org/guides/getting-started/maven-in-five-minutes.html 1)下载maven: ...
-
第四篇:python基础之dict、set及字符
python基础之dict.set及字符 python基础之dict.set及字符串处理 本节内容 字典介绍及内置方法 集合介绍 字符串处理 1.字典介绍及内置方法 字典是python中唯一的映射 ...
-
Qt 错误汇集贴
错误: D:\qtprojects\mycom\mycom\mainwindow.cpp:23: error: no matching function for call to 'MainWindow ...
-
修改Hosts不生效的一个场景-web(转)
Update: 如果浏览器使用了代理工具,修改 Hosts 也不会生效.这里是因为,浏览器会优先考虑代理工具(如添加 pac 文件.SwitchySharp等)的代理,建议调试的时候先关闭这些代理. ...
-
[GitHub]第八讲:GitHub Pages
Github Pages 是 github 公司提供的免费的静态网站托管服务,用起来方便而且功能强大,不仅没有空间限制,还可以绑定自己的域名.在 https://pages.github.com/ 首 ...
-
复旦大学2018--2019学年第一学期高等代数I期末考试情况分析
一.期末考试成绩90分以上的同学(共21人) 周烁星(99).封清(99).叶雨阳(97).周子翔(96).王捷翔(96).张思哲(95).丁思成(94).陈宇杰(94).谢永乐(93).张哲维(93 ...
-
wps表格开发C#
1.需要添加引用etapi.dll,这个dll在你的wps的安装目录下面可以找到. 2.主要的类: Excel.Application:顶层对象 WorkBook:工作簿 WorkSheet:表 Ra ...
- pgAdmin4 汉化