ホームページ >バックエンド開発 >PHPチュートリアル >php が mysql ストアド プロシージャを呼び出す_PHP チュートリアル
以前に「php が mysql ストアド プロシージャを呼び出す」という記事を再録しましたが、テストした結果、記事内の方法は実行不可能であることがわかりました。
select ステートメントを使用してストアド プロシージャを呼び出すと、「PROCEDURE p can't return a result set in the specific context」エラーが発生します。長い間グーグルで調べた結果、mysql公式Webサイトでdb_mysqlモジュールはストアドプロシージャ呼び出しをサポートしていないという記述を見つけました。解決策はdb_mysqliを使用することです。テストしてみたところ、動作しました。
使用法は比較的簡単で、言うことはありません。インターネットからコードをコピーするだけです:
/* MySQL サーバーに接続します */
$link = mysqli_connect(
'localhost ', /* 接続するホスト */
'root', /* 接続するユーザー */
'root', /* 使用するパスワード */
'db_name'); query */
if ( !$link) {
printf("MySQL サーバーに接続できません。エラーコード: %sn", mysqli_connect_error());
exit;
/* サーバーにクエリを送信します */
if ($result = mysqli_query($link, "call se_proc('crm')")) {
/* クエリの結果を取得します */
while( $row = mysqli_fetch_array($result) ){
echo ( $row[0]. "-------- SR. " . $row[1] . "
")
/* 結果セットに使用されているメモリを解放します */
mysqli_free_result($result);
}
/* 接続を閉じる */
mysqli_close($link)?>
イライラするのは、作成するのに長い時間がかかったストアド プロシージャがそれほど効率的ではないことです。前 - -