Web アプリケーションを開発する場合、多くの場合、ストアド プロシージャを呼び出して複雑なデータベース操作を実行する必要があります。 ThinkPHP5 は、人気のある PHP フレームワークとして、データベース操作のための便利で高速なソリューションを提供します。この記事では、ThinkPHP5 でストアド プロシージャを呼び出す方法を紹介します。
- ストアド プロシージャの作成
まず、データベースにストアド プロシージャを作成する必要があります。 MySQL を例として、次のストアド プロシージャを作成したとします。
DELIMITER $$ CREATE PROCEDURE user_login(IN `username` varchar(50), IN `password` varchar(50), OUT `result` varchar(20)) BEGIN SELECT COUNT(*) INTO result FROM user WHERE `username`=username AND `password`=password; END $$ DELIMITER ;
このストアド プロシージャは、ユーザーのログイン情報を確認するために使用され、2 つの入力パラメータ (ユーザー名とパスワード) と 1 つの出力パラメータ (login) を受け入れます。結果 。
- モデルでの呼び出し
次に、対応するモデルでストアド プロシージャを呼び出す必要があります。既存のモデルの場合は、対応するメソッドに次のコードを追加できます。
$result = Db::query("CALL user_login('".$username."','".$password."',@result);");
ここでは Db::query
メソッドを使用してストアド プロシージャを実行します。最初のパラメータはストアド プロシージャの SQL ステートメントです。パラメータ値は二重引用符で囲まれていることに注意してください。 2 番目のパラメーターは、ストアド プロシージャの出力を取得するために使用される参照変数です。その前に、出力結果を保存する変数を定義する必要があります:
$result = '';
最後に、ストアド プロシージャを実行する前に次のコードを追加して、出力パラメーターが正しく取得できることを確認する必要があります:
Db::query("SELECT @result AS result;");
Complete コードは次のとおりです。
public function login($username, $password) { $result = ''; Db::query("SELECT @result := '';"); $result = Db::query("CALL user_login('".$username."','".$password."',@result);"); Db::query("SELECT @result AS result;"); return intval($result[0]['result']) === 1; }
このうち、intval
関数は文字列を整数に変換するために使用されます。
新しいモデルの場合は、以下の手順に従います。
- 新しいモデル クラス (
UserModel
など) を作成し、次のコードを追加します。 ##
- コントローラーでモデル メソッドを呼び出します。例:
public function login() { $username = input('post.username'); $password = input('post.password'); if(UserModel::login($username, $password)){ return json(['code' => 0, 'message' => '登录成功']); } else { return json(['code' => -1, 'message' => '登录失败']); } }
- プログラムを実行します。すべてがうまくいけば、次のことができるはずです。ログインに成功しました。
- 概要
Db::query メソッドを使用する場合は、パラメーターの受け渡し方法と出力パラメーターの取得方法に注意する必要があります。ストアド プロシージャを合理的に使用することで、開発プロセス中に複雑なデータベース操作をより便利に実行できます。
以上がthinkphp5 はストアド プロシージャを呼び出しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ホットトピック









