ホームページ >バックエンド開発 >PHPチュートリアル >php で MySQL ストアド プロシージャを呼び出すメソッドのコレクション (推奨)_PHP チュートリアル

php で MySQL ストアド プロシージャを呼び出すメソッドのコレクション (推奨)_PHP チュートリアル

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-07-21 15:01:02715ブラウズ

タイプ 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) または die("クエリが失敗しました:".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( Except ion $e )
{
echo $e;
}
echo 'proc return message:'$Proc_Error.'
' //ストアドプロシージャから出力された変数を出力します
echo 'ユーザー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('MySQL サーバーに接続できません');
}
$db->query("SET NAMES UTF8");
$db->query("SET @Message");
if($db->real_query("call P__Test_GetData2(@Message)") )){
do{
if($result = $ db->store_result()){ $result->close(); }while($db->next_result()); ->close();
print_r($rows);
//手順
……
select * from T1 where ……
select * from T2 where ……
……





http://www.bkjia.com/PHPjc/328011.html

www.bkjia.com
tru​​e

http://www.bkjia.com/PHPjc/328011.html

タイプ 1: 入力型パラメーターと出力型パラメーターを使用してメソッドを呼び出します。 $returnValue = ''; try { mysql_query ( "set @Return" );
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。