프로시저와 마찬가지로 데이터베이스에 함수를 만들어 저장할 수도 있습니다.
구문
다음은 (MySQL) 데이터베이스에서 함수를 생성하는 구문입니다.
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 | +--------+------------+----------------+
아래의 Given은 함수를 생성하는 예입니다. 여기에서 getDob()이라는 함수를 만들고 있습니다. 직원의 이름을 받아들이고 DOB 열의 값을 검색하고 반환합니다.
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(?)}
쿼리에 준비된 호출 가능한 명령문과 마찬가지로 자리 표시자(?)가 포함되어 있는 것을 볼 수 있습니다.
위 쿼리에서 첫 번째 자리 표시자는 함수의 반환 값을 나타내고 두 번째 자리 표시자는 입력 매개변수를 나타냅니다.
registerOutParameter()를 사용하여 출력 매개변수로 반환 값을 나타내는 자리 표시자를 등록해야 합니다. 메서드(CallableStatement 인터페이스의). 이 메서드에는 자리 표시자의 위치를 나타내는 정수 값과 (매개변수의) 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)); } }
출력
Connection established...... Date of birth: 1970-01-08