MySQL分页存储过程及其调用
来源:互联网 发布:淘宝店铺解绑身份证 编辑:程序博客网 时间:2024/06/04 18:46
存储过程
DELIMITER $$USE `sxdb`$$DROP PROCEDURE IF EXISTS `Query_Pagination_ViewPage`$$CREATE DEFINER=`root`@`localhost` PROCEDURE `Query_Pagination_ViewPage`( $TableName VARCHAR(200), $FieldList VARCHAR(2000), $PrimaryKey VARCHAR(100), $WHERE VARCHAR(1000), $ORDER VARCHAR(1000), $SortType INT, $RecorderCount INT, $PageSize INT, $PageIndex INT, OUT $TotalCount INTEGER, OUT $TotalPageCount INTEGER )BEGIN IF !(($TableName IS NULL OR $TableName='') OR ($FieldList IS NULL OR $FieldList='') OR ($PrimaryKey IS NULL OR $PrimaryKey='') OR $SortType < 1 OR $SortType >3 OR $RecorderCount < 0 OR $PageSize < 0 OR $PageIndex < 0) THEN IF ($WHERE IS NULL OR $WHERE='') THEN SET @new_where1 = ' ' ; SET @new_where2 = ' WHERE ' ; ELSE SET @new_where1 =CONCAT(' WHERE ',$WHERE); SET @new_where2 =CONCAT(' WHERE ',$WHERE,' AND '); END IF; IF $ORDER='' OR $SortType = 1 OR $SortType = 2 THEN IF $SortType = 1 THEN SET @new_order =CONCAT(' ORDER BY ',$PrimaryKey,' ASC' ); END IF; IF $SortType = 2 THEN SET @new_order =CONCAT(' ORDER BY ',$PrimaryKey,' DESC'); END IF; ELSE SET @new_order =CONCAT(' ORDER BY ',$ORDER); END IF; SET @SqlCount = CONCAT('SELECT COUNT(*) into @TotalCount FROM ',$TableName,@new_where1); SET @SqlCount1 = CONCAT('SELECT CEILING((COUNT(*)+0.0)/',$PageSize,') into @TotalPageCount FROM ',$TableName,@new_where1); IF $RecorderCount = 0 THEN PREPARE stmt1 FROM @SqlCount; EXECUTE stmt1; SET $TotalCount=@TotalCount; PREPARE stmt1 FROM @SqlCount1; EXECUTE stmt1; SET $TotalPageCount=@TotalPageCount; ELSE SET $TotalCount = $RecorderCount; END IF; IF $PageIndex > CEILING(($TotalCount+0.0)/$PageSize) THEN SET $PageIndex = CEILING(($TotalCount+0.0)/$PageSize); END IF; IF $PageIndex = 0 OR $PageIndex = 1 THEN SET @SQL=CONCAT('SELECT ',$FieldList,' FROM ',$TableName,@new_where1,@new_order,' limit ',$PageSize); ELSE IF $SortType = 1 THEN SET @SQL=CONCAT('SELECT ',$FieldList,' FROM ',$TableName,@new_where2,$PrimaryKey,' > (SELECT max(',$PrimaryKey,') FROM (SELECT ',$PrimaryKey,' FROM ',$TableName,@new_where1,@new_order,' limit ',$PageSize*($PageIndex-1),' ) AS TMP) ',@new_order,' limit ',$PageSize); END IF; IF $SortType = 2 THEN SET @SQL=CONCAT('SELECT ',$FieldList,' FROM ',$TableName,@new_where2,$PrimaryKey,' < (SELECT MIN(',$PrimaryKey,') FROM (SELECT ',$PrimaryKey,' FROM ',$TableName,@new_where1,@new_order,' limit ',$PageSize*($PageIndex-1),' ) AS TMP) ',@new_order,' limit ',$PageSize); END IF; IF $SortType = 3 THEN IF INSTR($ORDER,',') > 0 THEN SET @SQL=CONCAT('SELECT ',$FieldList,' FROM ',$TableName,@new_where2,$PrimaryKey,' NOT IN (SELECT ',$PrimaryKey,' FROM (SELECT ',$PrimaryKey,' FROM ',$TableName,@new_where1,@new_order,' limit ',$PageSize*($PageIndex-1),' ) a)',@new_order,' limit ',$PageSize); ELSE SET @new_order =CONCAT(' ORDER BY ',$PrimaryKey,' ASC' ); SET @SQL=CONCAT('SELECT ',$FieldList,' FROM ',$TableName,@new_where2,$PrimaryKey,' > (SELECT max(',$PrimaryKey,') FROM (SELECT ',$PrimaryKey,' FROM ',$TableName,@new_where1,@new_order,' limit ',$PageSize*($PageIndex-1),' ) AS TMP) ',@new_order,' limit ',$PageSize); END IF; END IF; END IF; PREPARE stmt2 FROM @SQL; EXECUTE stmt2; END IF; END$$DELIMITER ;
调用
CALL Query_Pagination_ViewPage('t_item','*','id','','id desc',2,0,15,1,@a,@b); SELECT @a,@b
0 0
- MySQL分页存储过程及其调用
- JAVA调用MYSQL存储过程实现分页
- 存储过程及其调用
- 分页存储过程调用
- mysql 分页存储过程
- MySQL 分页存储过程
- MySql分页存储过程
- MySql分页存储过程
- MySql分页存储过程
- MySql分页存储过程
- MySql分页存储过程
- MySql分页存储过程
- Mysql分页存储过程
- Mysql分页存储过程
- Mysql分页存储过程
- MySql 分页存储过程
- mysql 分页存储过程
- MySQL分页存储过程
- 越来越沉默
- light oj 1027 A Dangerous Maze(期望)
- 浅谈Unix/linux下的内存管理
- Android开发,如何成功将默认的图标换成自己设置的
- PHP初学问题汇总
- MySQL分页存储过程及其调用
- poj 3259 Wormholes
- Red Hat配置镜像media为yum源
- 终于写下一行伟大的代码
- 【Env】Solaris10下安装gcc-5.1.0
- Struts2 中拦截器和Action的调用关系
- 指针的危险
- 2440裸机开发
- 【Caffe代码解析】SyncedMemory