> 데이터 베이스 > MySQL 튜토리얼 > Callable 문을 사용하여 함수를 호출할 수 있나요? JDBC 예제를 사용하여 설명할 수 있나요?

Callable 문을 사용하여 함수를 호출할 수 있나요? JDBC 예제를 사용하여 설명할 수 있나요?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2023-08-27 18:37:09
앞으로
509명이 탐색했습니다.

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

프로시저와 마찬가지로 데이터베이스에 함수를 생성하고 저장할 수도 있습니다.

Syntax

다음은 (MySQL) 데이터베이스에서 함수를 생성하는 구문입니다.

Syntax

다음은 (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(?)}
로그인 후 복사

보시다시피 쿼리에는 준비된 문 및 호출 가능 문과 마찬가지로 자리 표시자(?)가 포함되어 있습니다.

위 쿼리에서 첫 번째 자리 표시자는 함수의 반환 값을 나타내고 두 번째 자리 표시자는 입력을 나타냅니다.

반환 값을 나타내는 자리 표시자를 배치하려면 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿