1>通用分页存储过程代码及调用

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
Java代码   收藏代码
  1. /***************************************************** 
  2. MySQL分页存储过程 
  3. 吴剑 2009-07-02   
  4. *****************************************************/  
  5. DROP PROCEDURE IF EXISTS pr_pager;  
  6. CREATE PROCEDURE pr_pager(  
  7.     IN     p_table_name        VARCHAR(1024),        /*表名*/  
  8.     IN     p_fields            VARCHAR(1024),        /*查询字段*/  
  9.     IN     p_page_size         INT,                  /*每页记录数*/  
  10.     IN     p_page_now          INT,                  /*当前页*/  
  11.     IN     p_order_string      VARCHAR(128),         /*排序条件(包含ORDER关键字,可为空)*/    
  12.     IN     p_where_string      VARCHAR(1024),        /*WHERE条件(包含WHERE关键字,可为空)*/      
  13.     OUT    p_out_rows          INT                   /*输出记录总数*/      
  14. )  
  15. NOT DETERMINISTIC  
  16. SQL SECURITY DEFINER  
  17. COMMENT '分页存储过程'  
  18.       
  19. BEGIN  
  20.   
  21.     /*定义变量*/  
  22.     DECLARE m_begin_row INT DEFAULT 0;  
  23.     DECLARE m_limit_string CHAR(64);  
  24.   
  25.     /*构造语句*/      
  26.     SET m_begin_row = (p_page_now - 1) * p_page_size;  
  27.     SET m_limit_string = CONCAT(' LIMIT ', m_begin_row, ', ', p_page_size);  
  28.       
  29.     SET @COUNT_STRING = CONCAT('SELECT COUNT(*) INTO @ROWS_TOTAL FROM ', p_table_name, ' ', p_where_string);  
  30.     SET @MAIN_STRING = CONCAT('SELECT ', p_fields, ' FROM ', p_table_name, ' ', p_where_string, ' ', p_order_string, m_limit_string);  
  31.   
  32.     /*预处理*/  
  33.     PREPARE count_stmt FROM @COUNT_STRING;  
  34.     EXECUTE count_stmt;  
  35.     DEALLOCATE PREPARE count_stmt;  
  36.     SET p_out_rows = @ROWS_TOTAL;  
  37.   
  38.     PREPARE main_stmt FROM @MAIN_STRING;  
  39.     EXECUTE main_stmt;  
  40.     DEALLOCATE PREPARE main_stmt;  
  41.       
  42. END;  

1取记录调用:

Java代码   收藏代码
  1. call pr_pager('表名''*'251''''@count_rows);  
  2. call pr_pager('user''*'152'''where id>3'@count_rows);  
  3. call pr_pager('user''*'151'group by password order by id desc'''@count_rows);  

2调用1后再取条数调用:

Java代码   收藏代码
  1. select @count_rows;   
  2. select @MAIN_STRING //select sql  
  3. select @COUNT_STRING  //seelct count sql  

支持多表级联 ,分组 :call pr_pager('job j left join enter_job ej on j.job_no=ej.job_no','j.*,ej.*','25','1','group byej.put_away_user order by ej.put_away_user desc','where j.job_table="enter"',@p_out_rows);

Java代码   收藏代码
  1. <?php  
  2. function dump_single_form41report($sys_report_id) {  
  3.     $this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);  
  4.     //SET @a=1;CALL dbpi_report.simpleproc(@a);SELECT @a;  
  5.     $sql = "CALL dbpi_temp.dumpSingleReportForm41($sys_report_id);";  
  6.     $result = $this->dbConn->query($sql);  
  7.     if (mysql_error()) {  
  8.         die (mysql_error().'<b>:</b> dump_single_form41report(...)['.__LINE__.'];<br>'.$sql);  
  9.     }  
  10.     return $result;  
  11. }  
  12.   
  13. function initQueuePool($sys_report_id, $username){  
  14.     $this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);  
  15.     $this->checkPreviousThread($sys_report_id, $username);  
  16.   
  17.     $temptablename  = "_".$username."_".$sys_report_id;  
  18.     $sql = "SET @a=".$sys_report_id.";";  
  19.     $this->dbConn->query($sql);  
  20.     $sql = "SET @b='".DB_REPORT.".".$temptablename."';";  
  21.     $this->dbConn->query($sql);  
  22.     $sql = "SET @c='".DB_PREPRODUCT."';";  
  23.     $this->dbConn->query($sql);  
  24.     $sql = "CALL ".DB_REPORT.".fm41_simpleproc(@a,@b,@c);";  
  25.     $this->dbConn->query($sql);  
  26. }   

 普通的查询,只返回一个结果集,而存储过程却返回至少两个结果集,其中一个就是存储过程的执行状态。我们必须要清除了这个执行状态以后,才可能再次调用另外一个存储过程 。

Java代码   收藏代码
  1. <?php  
  2. $rs=mysql_query("call pr_pager('change_monitor','*',10,1,'','',@p_out_rows)");  
  3. while($rows=mysql_fetch_array($rs)){  
  4.     echo $rows[Schedule];  
  5. }  
  6. $query=mysql_query("select @p_out_rows");  
  7. $v=mysql_fetch_array($query);   

can't return a result set in the given context

需要php调用存储过程,返回一个结果集,发现很困难,找了半天,终于在老外的论坛上找到解决方案,这里本地化一下。

关键就是两点

1)define('CLIENT_MULTI_RESULTS', 131072);

2)$link = mysql_connect("127.0.0.1", "root", "",1,CLIENT_MULTI_RESULTS) or die("Could not connect: ".mysql_error());

 

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
存储
SQLServer分页获取数据的存储过程
SQLServer分页获取数据的存储过程
24 0
|
6月前
|
存储 开发框架 前端开发
基于MySQL 实现通用分页存储过程(下篇-超详细)(上)
基于MySQL 实现通用分页存储过程(下篇-超详细)
65 0
|
6月前
|
存储 XML 安全
基于MySQL 实现通用分页存储过程(下篇-超详细)(下)
基于MySQL 实现通用分页存储过程(下篇-超详细)
37 0
|
9月前
|
存储
【干货】SqlServer 总结几种存储过程分页的使用
【干货】SqlServer 总结几种存储过程分页的使用
|
11月前
|
存储 SQL Perl
PL/SQL编程—分页功能(存储过程)
PL/SQL编程—分页功能(存储过程)
87 0
|
存储
通用分页存储过程,干货无污染
通用分页存储过程,干货无污染
|
存储 SQL Java
MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
一、用到的实体类如下: Student.java [html] view plaincopy   package com.company.entity;      import java.
907 0
|
存储 SQL 数据库连接
再上数据分页控件(不用存储过程)
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chinahuyong/article/details/6301411 再上数据分页控件(不用存储过程) 发布日期:2011年04月04日 星期一 作者:EricHu   本篇主要内容如下: ·     概述 ·     本分页控件原理。
744 0