C# MySql分页存储过程的应用
存储过程:
获取范围内的数据
DELIMITER $$ DROP PROCEDURE IF EXISTS `studb`.`GetRecordAsPage` $$ CREATE PROCEDURE `studb`.`GetRecordAsPage` (in tbName varchar(800),in fldName varchar(1000), in strWhere varchar(500),in pageIndex int,in pageSize int,in orderType int,in sortName varchar(50)) BEGIN declare startRow int; declare sqlStr varchar(1000); declare limitTemp varchar(1000); declare orderTemp varchar(1000); set startRow = (pageIndex-1)*pageSize; set sqlStr = CONCAT('SELECT ',fldName,' from ',tbName); set limitTemp = CONCAT(' limit ',startRow,',',pageSize); set orderTemp = CONCAT(' order by ',sortName); if orderType = 0 then set orderTemp = CONCAT(orderTemp,' ASC '); else set orderTemp = CONCAT(orderTemp,' DESC '); end if; set @sqlString = CONCAT(sqlStr,' ',strWhere,orderTemp,limitTemp); prepare sqlstmt from @sqlString; execute sqlstmt; deallocate prepare sqlstmt; END $$ DELIMITER ;
获取条件下的总记录数据
DELIMITER $$ DROP PROCEDURE IF EXISTS `GetRecordCount` $$ -- --CREATE DEFINER=`root`@`localhost` PROCEDURE `GetRecordCount`(in tbName varchar(800),in strWhere varchar(500)) CREATE PROCEDURE `GetRecordCount`(in tbName varchar(800),in strWhere varchar(500)) BEGIN set @strSQL=concat('select count(*) as countStr from ',tbName,strWhere); prepare sqlstmt from @strSQL; execute sqlstmt; deallocate prepare sqlstmt; END $$ DELIMITER ;
测试
建表语句
CREATE TABLE `uinfo` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
`iduse` varchar(200) DEFAULT NULL COMMENT '用户编号',
`uname` varchar(200) DEFAULT NULL COMMENT '用户名称',
`email` varchar(200) DEFAULT NULL COMMENT 'Email',
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=latin1
测试脚本
SELECT
`id`
, `iduse`
, `uname`
, `email`
FROM
`mostimpressive_dscj`.`uinfo`; SET @tbName='uinfo'; -- -- 表名
SET @fldName='iduse,uname,email';-- -- 表的列名
SET @strWhere = ''; -- -- 查询条件
SET @pageIndex=1;-- -- 第几页 传入1就是显示第一页
SET @pageSize=5;-- -- 一页显示几条记录
SET @orderType=0; -- --0是升序 非0是降序
SET @sortName='id'; -- -- 排序字段 CALL Dscj_GetPaged('uinfo','iduse,uname,email','',1,1,1,'id')
-- --SELECT iduse,uname,email from uinfo order by id ASC limit 0,4 -- --传入表名,返回总的记录条数
CALL GetRecordCount('uinfo','')
C#程序
protected void get_data() { string strWhere = " where idmde='" + DropDownList1.SelectedValue + "' and idmke='" + DropDownList2.SelectedValue + "'"; string fldName = "iduse,uname,email,euser,werks"; int pageSize = ; int pageCount = ; int pageCountMod = ; int doCount = ; int pageIndex = System.Convert.ToInt32(pageIndexLab.Text.ToString()); myco = new MySqlConnection(strconn); myco.Open(); mycomm = new MySqlCommand("GetRecordCount", myco); mycomm.CommandType = CommandType.StoredProcedure; MySqlParameter[] para = new MySqlParameter[]{ new MySqlParameter("@tbName",MySqlDbType.VarChar,), new MySqlParameter("@strWhere",MySqlDbType.VarChar,)}; para[].Value = "uinfo"; para[].Value = strWhere; mycomm.Parameters.AddRange(para); MySqlDataReader mydr=mycomm.ExecuteReader(); while(mydr.Read()){ pageCount = System.Convert.ToInt32(mydr["countStr"].ToString()) ; pageCountMod = pageCount % pageSize; pageCount= pageCount/ pageSize; if (pageCount == ) { //pageCount++; } else { if (pageCountMod != ) { pageCount++; } } pageCountLab.Text = pageCount.ToString(); } if (pageIndex == ) { pageIndex++; } mydr.Close(); mycomm.Dispose(); mycomm = new MySqlCommand("GetRecordAsPage", myco); mycomm.CommandType = CommandType.StoredProcedure; para.Initialize(); para = new MySqlParameter[]{ new MySqlParameter("@tbName",MySqlDbType.VarChar,), new MySqlParameter("@fldName",MySqlDbType.VarChar,), new MySqlParameter("@strWhere",MySqlDbType.VarChar,), new MySqlParameter("@pageIndex",MySqlDbType.Int32), new MySqlParameter("@pageSize",MySqlDbType.Int32), new MySqlParameter("@orderType",MySqlDbType.Int16), new MySqlParameter("@sortName",MySqlDbType.VarChar,)}; para[].Value = "uinfo"; para[].Value = fldName; para[].Value = strWhere; para[].Value = pageIndex; para[].Value = pageSize; para[].Value = ; para[].Value = "iduse"; mycomm.Parameters.AddRange(para); MySqlDataAdapter myAdapter = new MySqlDataAdapter(mycomm); DataSet myDataSet = new DataSet(); DataView m_DataView = new DataView(); myAdapter.Fill(myDataSet); m_DataView = myDataSet.Tables[].DefaultView; GridView1.DataSource = m_DataView; GridView1.DataBind(); GridView2.DataSource = m_DataView; GridView2.DataBind(); GridView3.DataSource = m_DataView; GridView3.DataBind(); DropDownpage.Items.Clear(); if (pageCount != ) { doCount = ; while (doCount < pageCount) { doCount++; DropDownpage.Items.Add(new ListItem(doCount.ToString()+"页", doCount.ToString())); } } if (pageIndex == ) { Button_IndexFirst.Enabled = false; Button_IndexPrevious.Enabled = false; Button_IndexNext.Enabled = true; Button_IndexLast.Enabled = true; } else if (pageIndex == pageCount) { Button_IndexFirst.Enabled = true; Button_IndexPrevious.Enabled = true; Button_IndexNext.Enabled = false; Button_IndexLast.Enabled = false; } else { Button_IndexFirst.Enabled = true; Button_IndexPrevious.Enabled = true; Button_IndexNext.Enabled = true; Button_IndexLast.Enabled = true; } if (pageCount == || pageCount == ) { pageIndex = pageCount; Button_IndexFirst.Enabled = false; Button_IndexPrevious.Enabled = false; Button_IndexNext.Enabled = false; Button_IndexLast.Enabled = false; DropDownpage.Enabled = false; } else { DropDownpage.Enabled = true; } pageIndexLab.Text = pageIndex.ToString(); if (pageIndex != ) { DropDownpage.SelectedItem.Selected = false; DropDownpage.Items.FindByValue(pageIndex.ToString()).Selected = true; } myco.Close(); } protected void Button_IndexFirst_Click(object sender, EventArgs e) { pageIndexLab.Text = ""; if (pageCountLab.Text.Equals("")) { pageIndexLab.Text = ""; } get_data(); } protected void Button_IndexPrevious_Click(object sender, EventArgs e) { int pageIndex = System.Convert.ToInt32(pageIndexLab.Text.ToString()); pageIndex--; if (pageIndex < ) { pageIndex = ; } pageIndexLab.Text = pageIndex.ToString(); get_data(); } protected void Button_IndexNext_Click(object sender, EventArgs e) { int pageIndex = System.Convert.ToInt32(pageIndexLab.Text.ToString()); int pageCount = System.Convert.ToInt32(pageCountLab.Text.ToString()); pageIndex++; if (pageIndex > pageCount) { pageIndex = pageCount; } pageIndexLab.Text = pageIndex.ToString(); get_data(); } protected void Button_IndexLast_Click(object sender, EventArgs e) { int pageIndex = System.Convert.ToInt32(pageIndexLab.Text.ToString()); int pageCount = System.Convert.ToInt32(pageCountLab.Text.ToString()); pageIndex = pageCount; pageIndexLab.Text = pageIndex.ToString(); get_data(); } protected void DropDownpage_SelectedIndexChanged(object sender, EventArgs e) { pageIndexLab.Text = DropDownpage.SelectedValue; get_data(); }
C# MySql分页存储过程的应用的更多相关文章
- MYSQL分页存储过程及事务处理
最近给客户做的一小系统是SQLSERVER的数据库,因为特殊原因要切换到MYSQL上去,切换数据库确实让人头疼的,SQLSERVER和MYSQL的存储过程还是有很大差别的,下面是我做切换时转换的MYS ...
- MYSQL分页存储过程及事务处理--转自peace
MYSQL的分页过程,和事务处理的一个测试过程. /* --名称:MYSQL版查询分页存储过程 by peace 2013-8-14 --输入参数:@fields -- 要查询的字段用逗号隔开 --输 ...
- 调用MySql 分页存储过程带有输入输出参数
Create PROCEDURE getuser ( IN pageIndex INT, IN pageSize INT, OUT count INT ) BEGIN )*pageSize; sele ...
- mysql 分页存储过程 一次返回两个记录集(行的条数,以及行记录),DataReader的Read方法和NextResult方法
DELIMITER $$ USE `netschool`$$ DROP PROCEDURE IF EXISTS `fn_jk_GetCourses`$$ CREATE DEFINER=`root`@` ...
- mysql分页存储过程一步一步实现
1. CREATE DEFINER=`root`@`localhost` PROCEDURE `P_HoverTreePages`( ), ) , ), ), ), IN `SortType` INT ...
- MySQL分页存储过程
CREATE PROCEDURE ProcPage(in tableName varchar(20),#表名 in showField varchar(100),#要显示的列名 in whereT ...
- MySql通用分页存储过程
MySql通用分页存储过程 1MySql通用分页存储过程 2 3过程参数 4p_cloumns varchar(500),p_tables varchar(100),p_where varchar(4 ...
- MYSQL版查询分页存储过程
/*--名称:MYSQL版查询分页存储过程 --输入参数:@fields -- 要查询的字段用逗号隔开--输入参数:@tables -- 要查询的表--输入参数:@where -- 查询条件--输入参 ...
- mysql通用分页存储过程遇到的问题(转载)
mysql通用分页存储过程遇到的问题(转载) http://www.cnblogs.com/daoxuebao/archive/2015/02/09/4281980.html
随机推荐
- python之else总结
python中除了if...elif...else..还有while...else, for...else..., try...except...else...finally... 不管哪种else, ...
- html笔记 仅适用于个人
如何使图片与文本框上下对齐 其实就给<img>加一个属性 align="absmiddle" <form method="post" acti ...
- Sql例子Sp_ExecuteSql 带参数
Declare @i int, @projectCount int ) --参数 ) ) ) ) ) ) --循环变量起始 --得到所有的项目 select @projectCount = count ...
- [转载]Windows 7 IIS (HTTP Error 500.21 - Internal Server Error)解决
今天在测试网站的时候,在浏览器中输入http://localhost/时,发生如下错误: HTTP Error 500.21 - Internal Server Error Handler " ...
- iOS开发网络编程之断点续传-NSURLConnection
最近在做一个小项目的时候,发现使用NSURLSession或者AFNNetworking进行断点续传时诸多的不便,于是自己封装了一个类来实现断点续传,在程序重新启动时仍然可以继续下载(需自己调用方法) ...
- PAT-乙级-1055. 集体照 (25)
1055. 集体照 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 拍集体照时队形很重要,这里对给定的N ...
- [设计模式] 20 状态模式 State Pattern
在GOF的<设计模式:可复用面向对象软件的基础>一书中对状态模式是这样说的:允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改了它的类.状态模式的重点在于状态转换,很多时候,对 ...
- NGINX的奇淫技巧 —— 6. IF实现数学比较功能 (1)
NGINX的奇淫技巧 —— 6. IF实现数学比较功能 (1) ARGUS 1月13日 发布 推荐 0 推荐 收藏 3 收藏,839 浏览 nginx的if支持=.!= 逻辑比较, 但不支持if中 & ...
- Chp4: Trees and Graphs
1.Type of Tree 1. Binary Tree: a binary tree is a tree in which each node has at most two child node ...
- Java注解全面解析
1.基本语法 注解定义看起来很像接口的定义.事实上,与其他任何接口一样,注解也将会编译成class文件. @Target(ElementType.Method) @Retention(Retentio ...