php呼び出しMySQLストアド・プロシージャ・メソッドのセット


タイプ1:入力、出力タイプパラメータを呼び出す方法
$returnValue = '';
try {
	mysql_query ( "set @Return" );
	$spname = 'P__Test_GetInfo1';
	mysql_query ( "call $spname(@Return, '{$userId}', '{$pwd}')" ) or die ( "[$spname]Query failed:" . mysql_error () );
	$result_return = mysql_query ( "select @Return" );
	$row_return = mysql_fetch_row ( $result_return );
	$returnValue = $row_return [0];
} catch ( Exception $e ) {
	echo $e;
}
echo $returnValue; //              

タイプ2:複数の出力タイプと複数の入力タイプパラメータを持つメソッドを呼び出す
$userId = 0;
try{
    mysql_query("set @Message");
    mysql_query("set @Id");
    mysql_query("call P__Test_Login(@Message, @Id, '{$userId}', '{$pwd}')", $conn) or die("Query failed:".mysql_error());
    $result_mess = mysql_query("select @Message");
    $result_uid = mysql_query("select @Id");
    $row_mess = mysql_fetch_row($result_mess);
    $row_uid = mysql_fetch_row($result_uid);
    $Proc_Error = $row_mess[0];
    $uId = $row_uid[0];
}
catch( Exception $e )
{
   echo $e;
}
echo 'proc return message:'$Proc_Error.'<br/>'; //              
echo 'User id:'.$uId; //    id

タイプ3:結果セットを返すメソッドを呼び出す
try {
	$spname = 'P__Test_GetData';
	$query = mysql_query ( "call $spname()", $conn ) or die ( "[$spname]Query failed:".mysql_error() );
	while ( $row = mysql_fetch_array ( $query ) ) {
		echo $row ['ProvinceID'].'::'.$row ['ProvinceName']; //     
	}
	
} catch ( Exception $e ) {
	echo $e;
}

タイプ4:呼び出しバンドが複数の結果セットを返す方法(現在はmysqliでしか実現できません~~~~)
//PHP
$rows = array ();  
$db = new mysqli($server,$user,$psd,$dbname);  
if (mysqli_connect_errno()){  
    $this->message('Can not connect to MySQL server');  
}  
$db->query("SET NAMES UTF8");  
$db->query("SET @Message");
if($db->real_query("call P__Test_GetData2(@Message)")){  
    do{  
        if($result = $db->store_result()){  
            while ($row = $result->fetch_assoc()){  
                array_push($rows, $row);  
            }  
            $result->close();  
        }  
    }while($db->next_result());  
}  
$db->close(); 
print_r($rows);

//Procedure 
……
select * from T1 where ……
select * from T2 where ……
……