プロシージャと同様に、関数を作成してデータベースに保存することもできます。
次は、(MySQL) データベースに関数を作成するための構文です。
次は、(MySQL) データベースに関数を作成するための構文です。 (MySQL) データベース内の関数 構文: p>
CREATE FUNCTION Function_Name(input_arguments) RETURNS output_parameter BEGIN declare variables; statements . . . . . . . . . . return data_type; END
データベースに Emp という名前のテーブルがあり、その内容が次のとおりであるとします:
+--------+------------+----------------+ | Name | DOB | Location | +--------+------------+----------------+ | Amit | 1970-01-08 | Hyderabad | | Sumith | 1970-01-08 | Vishakhapatnam | | Sudha | 1970-01-05 | Vijayawada | +--------+------------+----------------+
作成関数の例を以下に示します。ここでは、従業員の名前を受け取り、DOB 列の値を取得して返す getDob() という関数を作成します。
CREATE FUNCTION getDob(emp_name VARCHAR(50)) RETURNS DATE BEGIN declare dateOfBirth DATE; select DOB into dateOfBirth from EMP where Name = emp_name; return dateOfBirth; END
ストアド プロシージャと同じように、CallableStatement オブジェクトを使用して関数を呼び出し、必要な JDBC プログラムを使用して関数を呼び出すことができます。
データベースに接続します。
PreparedStatement オブジェクトを作成し、それをコンストラクターに渡して、文字列形式で関数を呼び出します。
値をプレースホルダーとして設定します。
Callable ステートメントを実行します。
JDBC から関数を呼び出すクエリは次のとおりです:
{? = call getDob(?)}
ご覧のとおり、クエリにはプリペアド ステートメントと同様にプレースホルダー (?) が含まれています。呼び出し可能なステートメント。
上記のクエリでは、最初のプレースホルダーは関数の戻り値を表し、2 番目のプレースホルダーは入力を表します。
CallableStatement インターフェイスの registerOutParameter() を使用する必要があります このメソッドは、戻り値を表すプレースホルダーを出力パラメーターとして登録します。このメソッドでは、プレースホルダーの位置を表す整数値と、(パラメーターの) SQL タイプを表す整変数を渡す必要があります。
cstmt.registerOutParameter(1, Types.DATE);
setString() メソッドを使用して、値を入力パラメーターに設定します。 (getDoc() 関数は VARCHAR 型の値を受け入れるため)。
次の JDBC プログラムは関数 getDob を実行し、結果を取得します: p>
import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Types; public class CallingFunctionsUsingCallable2 { public static void main(String args[]) throws SQLException { //Registering the Driver DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //Getting the connection String mysqlUrl = "jdbc:mysql://localhost/sampleDB"; Connection con = DriverManager.getConnection(mysqlUrl, "root", "password"); System.out.println("Connection established......"); //Preparing a CallableStatement CallableStatement cstmt = con.prepareCall("{? = call getDob(?)}"); cstmt.registerOutParameter(1, Types.DATE); cstmt.setString(2, "Amit"); cstmt.execute(); System.out.print("Date of birth: "+cstmt.getDate(1)); } }
Connection established...... Date of birth: 1970-01-08
以上がCallableステートメントを使用して関数を呼び出すことはできますか? JDBCの例を使って説明していただけますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。