MySQL ストアド プロシージャは正常に実行されましたが、PHP は値を取得できません。
begin
destroy tmp varchar(100);
destroy tmpjf int(10); if empid>0 then
#select REPLACE(empfixed,'.',',') where id=empid into @tmp; select substring(REPLACE(empfixed,'.',',' ) ,2,char_length(empfixed) -2) into @tmp from kyydemploy where id=empid ;
end if; set @sel='select sum(dejifen) ) kyydeinter から @tmpjf に id in (';
set @selt=')';
@conds から stmt を準備する
stmt; deallocate prepare stmt;
select @tmpjf into bb;
end
ここで、bb は返された単語の値 int 型です。
cmd または navicat を使用して実行できます。ただし、phpでは値を取得できません。また、単純なストアド プロシージャ select 888 into bb も使用しましたが、これは php で取得できます。何が問題なのか教えていただけますか?
ディスカッションへの返信 (解決策)
ストアド プロシージャは 2 つの結果セットを返します (条件 empid>0 が true の場合、3 つの結果セットになります) ただし、mysql 関数グループには関数がありません結果セットポインタを移動するため、select @tmpjf into bb; の結果を読み取ることができません (最後の結果セットにあります)
操作するには mysqli 関数グループまたは PDO クラスを使用する必要があります
これが理由の 1 つですなぜ php 5.5 は mysql 関数グループを放棄したのか
ストアド プロシージャは 2 つの結果セットを返します (条件 empid>0 が true の場合、結果セットは 3 つになります)
しかし、mysql 関数グループには、結果セットポインターなので、select @tmpjf into bb; の結果は読み取れません (最後の結果セットにあります)
操作するには mysqli 関数グループまたは PDO クラスを使用する必要があります
これが php 5.5 の理由の 1 つですmysql 関数グループを放棄しました
わかりました。 3Q. つまり、ストアド関数は 1 つの結果のみを返すのが最適です
データベース操作の拡張機能を変更せずに (変更した場合、プログラムの変更は小さくありません)、mysql_next_result 関数を実行してみることができます。クエリ
RRee

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。
