C#调用存储过程实现分页(个人代码笔记)
分页的存储过程:
drop proc LoadPageMain create Proc LoadPageMain
@pageIndex int,
@pageSize int,
@count int out
as
select top(@pageSize) * from dbo.MyStudent
where Fid not in
(
select top(@pageSize*(@pageIndex-1)) Fid
from dbo.MyStudent
order by Fid
)
order by Fid
select @count=COUNT(1) from dbo.MyStudent DAL层调用分页存储过程: public List<Model.MyStudent> getPagedList(int pageIndex, int pageSize, out int count)
{
List<Model.MyStudent> modelList = new List<Model.MyStudent>(); //创建最终要返回的model 的 List集合对象 string connStr = "server=.;database=CCDB;uid=sa;pwd=130988825"; using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand()) //创建command对象
{
cmd.Connection = conn;
cmd.CommandType = CommandType.StoredProcedure; 设置command 对象的type属性
cmd.CommandText = "LoadPageMain"; //指定相应的存储过程 cmd.Parameters.Add(new SqlParameter("@pageIndex",pageIndex)); //为存储过程添加参数
cmd.Parameters.Add(new SqlParameter("@pageSize",pageSize));
SqlParameter outCount = new SqlParameter("@count",SqlDbType.Int); //创建将要输出的参数,并添加到参数集合中
outCount.Direction = ParameterDirection.Output;
cmd.Parameters.Add(outCount); conn.Open(); using (SqlDataAdapter sda = new SqlDataAdapter(cmd)) //用SqlDataReader 对象回去数据,不用担心conn断开的问题
{
DataSet ds = new DataSet();
sda.Fill(ds); //获取存储过程返回的数据集 count = (int)outCount.Value; // 注意:获取 存储过程输出的参数值 foreach (DataRow row in ds.Tables[0].Rows )
{
Model.MyStudent model = new Model.MyStudent(); model.FName = Convert.ToString(row[1]);
model.FAge = Convert.ToInt32(row[2]);
model.FGender = Convert.ToString(row[3]);
model.FMath = row[4] is DBNull?null: (int?)Convert.ToInt32(row[4]);
model.FEnglish = Convert.ToInt32(row[5]);
model.FClassId = Convert.ToInt32(row[6]);
model.FBirthday = Convert.ToDateTime(row[7]); modelList.Add(model);
}
} }
}
return modelList;
} aspx页面输出分页的方式: 在后台拼接字符串(数据输出的、分页连接的)输出到前台,后台通过前台传来的pageIndex、pageSize参数来动态改变数据 protected void Page_Load(object sender, EventArgs e)
{
int count = 0;
int pageIndex = Request["pageIndex"]==null?1:Convert.ToInt32(Request["pageIndex"]);
int pageSize = Request["pageSize"]==null?20:Convert.ToInt32(Request["pageSize"]);
BLL.MyStudent bll_mystudent = new BLL.MyStudent();
List<Model.MyStudent> modelList= bll_mystudent.getPagedList(pageIndex, pageSize, out count); StringBuilder sb = new StringBuilder();
for (int i = 0; i < modelList.Count; i++)
{
sb.Append(string.Format("<tr> <td>" + modelList[i].FName + "</td> <td>" + modelList[i].FAge + "</td> <td>" + modelList[i].FGender + "</td> <td>" + modelList[i].FMath + "</td> <td>" + modelList[i].FEnglish + "</td> <td>" + modelList[i].FClassId + "</td> <td>" + modelList[i].FBirthday + "</td> <td>修改 删除 详情</td> </tr>"));
}
trBody = sb.ToString(); int pageCount=(count-1)/pageSize+1;
StringBuilder sbFY = new StringBuilder();
sbFY.Append("<a href='?pageSize=20&pageIndex=1'>上一页</a> ");
for (int i = 0; i < pageCount; i++)
{
sbFY.Append(string.Format("<a href='?pageSize=20&pageIndex={0}'>{0}</a> ", i, i));
}
sbFY.Append("<a href='?pageSize=20&pageIndex=1'>下一页</a> ");
strFY = sbFY.ToString();
}
C#调用存储过程实现分页(个人代码笔记)的更多相关文章
- MyBatis之四:调用存储过程含分页、输入输出参数
在前面分别讲解了通过mybatis执行简单的增删改,多表联合查询,那么自然不能缺少存储过程调用,而且还带分页功能. 注意:表结构参见上篇讲解联合查询的表. 一.查询某班级以及该班级下面所有学生的记录 ...
- Ibatis调用存储过程实现增删改以及分页查询
1.Ibatis实现增删改操作很简单了,通常我是将某一模块的增删改功能写在一个存储过程里,通过一个标识符去区分执行增加还是修改抑或删除操作. statement: <!-- 存储过程:实现学生的 ...
- Java数据库连接--JDBC调用存储过程,事务管理和高级应用
相关链接:Jdbc调用存储过程 一.JDBC常用的API深入详解及存储过程的调用 1.存储过程的介绍 我们常用的操作数据库语言SQL语句在执行的时候要先进行编译,然后执行,而存储过程是在大型数据库系统 ...
- Sybase·调用存储过程并返回结果
最近项目要用Sybase数据库实现分页,第一次使用Sybase数据库,也是第一次使用他的存储过程.2个多小时才调用成功,在此记录: 项目架构:SSM 1.Sybase本身不支持分页操作,需要写存储过程 ...
- [原创]java WEB学习笔记79:Hibernate学习之路--- 四种对象的状态,session核心方法:save()方法,persist()方法,get() 和 load() 方法,update()方法,saveOrUpdate() 方法,merge() 方法,delete() 方法,evict(),hibernate 调用存储过程,hibernate 与 触发器协同工作
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- 我也谈谈 代码调用存储过程超时,SQL Server Management Studio里运行很快的问题
最近遇到了一个问题就是 一个执行速度很快的存储过程,在代码中调用的时候却超时了. 后来看到了两篇文章: 其中一篇是这样介绍的 今天同事用代码调用存储过程时超时,在SQL Server Manageme ...
- ADO.NET笔记——调用存储过程
相关知识: 在ADO.NET访问SQL Server时,鼓励使用存储过程取代常规的SQL语句. 存储过程有下列优点: 存储过程中的SQL语句将会经过预先的解析和编译,然后存放在数据库服务器上行.调用的 ...
- MyBatis学习笔记(六)——调用存储过程
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4270352.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据 ...
- MySQL学习笔记:调用存储过程或函数报1418错误
问题 MySQL开启bin-log后,调用存储过程或者函数以及触发器时,会出现错误号为1418的错误: ERROR 1418 (HY000): This function has none of DE ...
随机推荐
- java int and string convert
int -> String int i=12345; String s=""; 第一种方法:s=i+""; 第二种方法:s=String.valueOf( ...
- IE 兼容性问题
1.IE6-IE7 可能会有2个class属性,真TMD蛋疼,一个是初始的,后来的是js赋值的 2.不同浏览器的标签默认的margin和padding不同 解决方法: * { margin:0; pa ...
- USB CCID协议和PC/SC标准
CCID是USB Chip/Smart Card Interface Devices,也就是USB芯片智能卡接口设备,是USB规范下的一种设备类型.就像HID设备一样,需要参考USB规范来写固件程序来 ...
- 基于visual Studio2013解决C语言竞赛题之0301函数求值
题目 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <math.h> void main() ...
- STL vector使用方法介绍
介绍 这篇文章的目的是为了介绍std::vector,怎样恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
- Android学习——百度地图开发定位与显示Demo
百度地图给我们提供了很丰富的API供我们进行二次开发.百度地图的SDK与定位SDK在今年6月份进行了更新. 地图更新为3.0,定位更新为4.2.百度说:这次更新对接口有了较大部分的调整,与之前版本号不 ...
- Linux 多线程通信
摘自资料(linux 与Windows不同) 线程间无需特别的手段进行通信,由于线程间能够共享数据结构,也就是一个全局变量能够被两个线程同一时候使用.只是要注意的是线程间须要做好同步,一般用mutex ...
- css中的@inport 与link
在html 代码中我们常常用分离的思想引入外部的css文件,常用的方法有2种,@import 语法: <style type="text/css" media="s ...
- c++,命名空间(namespace)
1.什么是命名空间: 命名空间:实际上就是一个由程序设计者命名的内存区域,程序设计者可以根据需要指定一些有名字的空间域,把一些全局实体分别放在各个命名空间中,从而与其他全局实体分隔开来. 2.命名空间 ...
- VMware Workstation9安装Mac OS X10.9系统
链接地址:http://jingyan.baidu.com/article/aa6a2c142cef740d4c19c426.html VMware Workstation9.0安装Mac OS X1 ...