1>공통 페이지 저장 프로세스 코드 및 호출
4748 단어 저장 프로세스mysql 페이지 나누기
/*****************************************************
MySQL
2009-07-02
*****************************************************/
DROP PROCEDURE IF EXISTS pr_pager;
CREATE PROCEDURE pr_pager(
IN p_table_name VARCHAR(1024), /* */
IN p_fields VARCHAR(1024), /* */
IN p_page_size INT, /* */
IN p_page_now INT, /* */
IN p_order_string VARCHAR(128), /* ( ORDER , )*/
IN p_where_string VARCHAR(1024), /*WHERE ( WHERE , )*/
OUT p_out_rows INT /* */
)
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ' '
BEGIN
/* */
DECLARE m_begin_row INT DEFAULT 0;
DECLARE m_limit_string CHAR(64);
/* */
SET m_begin_row = (p_page_now - 1) * p_page_size;
SET m_limit_string = CONCAT(' LIMIT ', m_begin_row, ', ', p_page_size);
SET @COUNT_STRING = CONCAT('SELECT COUNT(*) INTO @ROWS_TOTAL FROM ', p_table_name, ' ', p_where_string);
SET @MAIN_STRING = CONCAT('SELECT ', p_fields, ' FROM ', p_table_name, ' ', p_where_string, ' ', p_order_string, m_limit_string);
/* */
PREPARE count_stmt FROM @COUNT_STRING;
EXECUTE count_stmt;
DEALLOCATE PREPARE count_stmt;
SET p_out_rows = @ROWS_TOTAL;
PREPARE main_stmt FROM @MAIN_STRING;
EXECUTE main_stmt;
DEALLOCATE PREPARE main_stmt;
END;
1 레코드 호출:
call pr_pager(' ', '*', 25, 1, '', '', @count_rows);
call pr_pager('user', '*', 15, 2, '', 'where id>3', @count_rows);
call pr_pager('user', '*', 15, 1, 'group by password order by id desc', '', @count_rows);
2 호출 1 후 항목 수 호출:
select @count_rows;
select @MAIN_STRING //select sql
select @COUNT_STRING //seelct count sql
다중 테이블 캐스케이드 지원, 그룹화:call prpager('job j left join enter_job ej on j.job_no=ej.job_no','j.*,ej.*','25','1','group by ej.put_away_user order by ej.put_away_user desc','where j.job_table="enter"',@p_out_rows);
<?php
function dump_single_form41report($sys_report_id) {
$this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);
//SET @a=1;CALL dbpi_report.simpleproc(@a);SELECT @a;
$sql = "CALL dbpi_temp.dumpSingleReportForm41($sys_report_id);";
$result = $this->dbConn->query($sql);
if (mysql_error()) {
die (mysql_error().'<b>:</b> dump_single_form41report(...)['.__LINE__.'];<br>'.$sql);
}
return $result;
}
function initQueuePool($sys_report_id, $username){
$this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);
$this->checkPreviousThread($sys_report_id, $username);
$temptablename = "_".$username."_".$sys_report_id;
$sql = "SET @a=".$sys_report_id.";";
$this->dbConn->query($sql);
$sql = "SET @b='".DB_REPORT.".".$temptablename."';";
$this->dbConn->query($sql);
$sql = "SET @c='".DB_PREPRODUCT."';";
$this->dbConn->query($sql);
$sql = "CALL ".DB_REPORT.".fm41_simpleproc(@a,@b,@c);";
$this->dbConn->query($sql);
}
일반적인 조회는 하나의 결과 집합만 되돌려주고 저장 프로세스는 적어도 두 개의 결과 집합을 되돌려준다. 그 중 하나는 저장 프로세스의 실행 상태이다.이 실행 상태를 제거해야만 다른 저장 프로세스를 다시 호출할 수 있습니다.
<?php
$rs=mysql_query("call pr_pager('change_monitor','*',10,1,'','',@p_out_rows)");
while($rows=mysql_fetch_array($rs)){
echo $rows[Schedule];
}
$query=mysql_query("select @p_out_rows");
$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());
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Java 호출 Oracle 스토리지 프로세스 상세 정보Java 호출 Oracle 스토리지 프로세스 상세 정보 단계: 1. Oracle 스토리지 프로세스 작성 2. 데이터베이스 작성 연결 도구 클래스 얻기 3. 간단한 응용 프로그램 호출 저장 프로세스 작성 구현: 1. ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.