ホームページ > データベース > mysql チュートリアル > Callableステートメントを使用して関数を呼び出すことはできますか? JDBCの例を使って説明していただけますか?

Callableステートメントを使用して関数を呼び出すことはできますか? JDBCの例を使って説明していただけますか?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2023-08-27 18:37:09
転載
512 人が閲覧しました

我们可以使用 Callable 语句调用函数吗?能用 JDBC 的例子解释一下吗?

プロシージャと同様に、関数を作成してデータベースに保存することもできます。

構文

次は、(MySQL) データベースに関数を作成するための構文です。

Syntax

次は、(MySQL) データベースに関数を作成するための構文です。 (MySQL) データベース内の関数 構文: p>

CREATE FUNCTION Function_Name(input_arguments) RETURNS output_parameter
BEGIN
   declare variables;
   statements . . . . . . . . . .
   return data_type;
   END
ログイン後にコピー

Example

データベースに 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
ログイン後にコピー

JDBC を使用した関数の呼び出し

ストアド プロシージャと同じように、CallableStatement オブジェクトを使用して関数を呼び出し、必要な JDBC プログラムを使用して関数を呼び出すことができます。

  • データベースに接続します。

  • PreparedStatement オブジェクトを作成し、それをコンストラクターに渡して、文字列形式で関数を呼び出します。

  • 値をプレースホルダーとして設定します。

  • Callable ステートメントを実行します。

JDBC から関数を呼び出すクエリは次のとおりです:

{? = call getDob(?)}
ログイン後にコピー

ご覧のとおり、クエリにはプリペアド ステートメントと同様にプレースホルダー (?) が含まれています。呼び出し可能なステートメント。

上記のクエリでは、最初のプレースホルダーは関数の戻り値を表し、2 番目のプレースホルダーは入力を表します。

CallableStatement インターフェイスの registerOutParameter() を使用する必要があります このメソッドは、戻り値を表すプレースホルダーを出力パラメーターとして登録します。このメソッドでは、プレースホルダーの位置を表す整数値と、(パラメーターの) SQL タイプを表す整変数を渡す必要があります。

cstmt.registerOutParameter(1, Types.DATE);
ログイン後にコピー

setString() メソッドを使用して、値を入力パラメーターに設定します。 (getDoc() 関数は VARCHAR 型の値を受け入れるため)。

次の JDBC プログラムは関数 getDob を実行し、結果を取得します:

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));
   }
}
ログイン後にコピー

Output

Connection established......
Date of birth: 1970-01-08
ログイン後にコピー

以上がCallableステートメントを使用して関数を呼び出すことはできますか? JDBCの例を使って説明していただけますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート