JDBC-저장 프로 시저

우리는 사용 방법을 배웠습니다 Stored ProceduresJDBC-Statements 장 을 논의하면서 JDBC에서 . 이 장은 해당 섹션과 유사하지만 JDBC SQL 이스케이프 구문에 대한 추가 정보를 제공합니다.

Connection 개체가 Statement 및 PreparedStatement 개체를 만드는 것처럼 데이터베이스 저장 프로 시저에 대한 호출을 실행하는 데 사용되는 CallableStatement 개체도 만듭니다.

CallableStatement 객체 생성

다음 Oracle 저장 프로 시저를 실행해야한다고 가정합니다.

CREATE OR REPLACE PROCEDURE getEmpName 
   (EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) AS
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END;

NOTE: 위의 저장 프로시 저는 Oracle 용으로 작성되었지만 MySQL 데이터베이스로 작업하고 있으므로 다음과 같이 MySQL 용 저장 프로 시저를 작성하여 EMP 데이터베이스에서 생성 해 보겠습니다.

DELIMITER $$

DROP PROCEDURE IF EXISTS `EMP`.`getEmpName` $$
CREATE PROCEDURE `EMP`.`getEmpName` 
   (IN EMP_ID INT, OUT EMP_FIRST VARCHAR(255))
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END $$

DELIMITER ;

IN, OUT 및 INOUT의 세 가지 유형의 매개 변수가 있습니다. PreparedStatement 오브젝트는 IN 매개 변수 만 사용합니다. CallableStatement 개체는 세 가지를 모두 사용할 수 있습니다.

다음은 각각의 정의입니다.

매개 변수 기술
SQL 문을 만들 때 값을 알 수없는 매개 변수입니다. setXXX () 메소드를 사용하여 IN 매개 변수에 값을 바인드합니다.
반환하는 SQL 문에서 값을 제공하는 매개 변수입니다. getXXX () 메소드를 사용하여 OUT 매개 변수에서 값을 검색합니다.
INOUT 입력 및 출력 값을 모두 제공하는 매개 변수입니다. setXXX () 메소드로 변수를 바인딩하고 getXXX () 메소드로 값을 검색합니다.

다음 코드 스 니펫은 Connection.prepareCall() 인스턴스화하는 방법 CallableStatement 이전 저장 프로 시저를 기반으로하는 개체-

CallableStatement cstmt = null;
try {
   String SQL = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   . . .
}

문자열 변수 SQL은 매개 변수 자리 표시자가있는 저장 프로 시저를 나타냅니다.

CallableStatement 개체를 사용하는 것은 PreparedStatement 개체를 사용하는 것과 매우 유사합니다. 명령문을 실행하기 전에 모든 매개 변수에 값을 바인드해야합니다. 그렇지 않으면 SQLException이 수신됩니다.

IN 매개 변수가있는 경우 PreparedStatement 오브젝트에 적용되는 동일한 규칙 및 기술을 따르십시오. 바인딩중인 Java 데이터 유형에 해당하는 setXXX () 메소드를 사용하십시오.

OUT 및 INOUT 매개 변수를 사용하는 경우 추가 CallableStatement 메소드 인 registerOutParameter ()를 사용해야합니다. registerOutParameter () 메소드는 JDBC 데이터 유형을 스토어드 프로 시저가 리턴 할 것으로 예상되는 데이터 유형에 바인드합니다.

저장 프로 시저를 호출하면 적절한 getXXX () 메서드를 사용하여 OUT 매개 변수에서 값을 검색합니다. 이 메소드는 검색된 SQL 유형 값을 Java 데이터 유형으로 캐스트합니다.

CallableStatement 객체 닫기

다른 Statement 객체를 닫는 것처럼 같은 이유로 CallableStatement 객체도 닫아야합니다.

close () 메서드에 대한 간단한 호출이 작업을 수행합니다. 먼저 Connection 개체를 닫으면 CallableStatement 개체도 닫힙니다. 그러나 적절한 정리를 위해 항상 CallableStatement 개체를 명시 적으로 닫아야합니다.

CallableStatement cstmt = null;
try {
   String SQL = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   cstmt.close();
}

우리는 Callable-Example Code 에서 더 자세한 내용을 연구했습니다 .

JDBC SQL 이스케이프 구문

이스케이프 구문은 표준 JDBC 메서드 및 속성을 사용하여 사용할 수없는 데이터베이스 특정 기능을 사용할 수있는 유연성을 제공합니다.

일반적인 SQL 이스케이프 구문 형식은 다음과 같습니다.

{keyword 'parameters'}

다음은 JDBC 프로그래밍을 수행하는 동안 매우 유용한 이스케이프 시퀀스입니다.

d, t, ts 키워드

날짜, 시간 및 타임 스탬프 리터럴을 식별하는 데 도움이됩니다. 아시다시피 두 DBMS는 시간과 날짜를 같은 방식으로 표현하지 않습니다. 이 이스케이프 구문은 드라이버에게 대상 데이터베이스 형식으로 날짜 또는 시간을 렌더링하도록 지시합니다. 예를 들어-

{d 'yyyy-mm-dd'}

여기서 yyyy = 연도, mm = 월; dd = 날짜. 이 구문을 사용하는 {d '2009-09-03'}은 2009 년 3 월 9 일입니다.

다음은 테이블에 날짜를 삽입하는 방법을 보여주는 간단한 예입니다.

//Create a Statement object
stmt = conn.createStatement();
//Insert data ==> ID, First Name, Last Name, DOB
String sql="INSERT INTO STUDENTS VALUES" +
             "(100,'Zara','Ali', {d '2001-12-16'})";

stmt.executeUpdate(sql);

마찬가지로 다음 두 구문 중 하나를 사용할 수 있습니다. t 또는 ts

{t 'hh:mm:ss'}

여기서 hh = 시간; mm = 분; ss = 초. 이 구문을 사용하면 {t '13 : 30 : 29 '}는 오후 1:30:29입니다.

{ts 'yyyy-mm-dd hh:mm:ss'}

이것은 타임 스탬프를 나타 내기 위해 'd'와 't'에 대한 위의 두 구문의 결합 구문입니다.

escape 키워드

이 키워드는 LIKE 절에서 사용되는 이스케이프 문자를 식별합니다. 0 개 이상의 문자와 일치하는 SQL 와일드 카드 %를 사용할 때 유용합니다. 예를 들면-

String sql = "SELECT symbol FROM MathSymbols
              WHERE symbol LIKE '\%' {escape '\'}";
stmt.execute(sql);

백 슬래시 문자 (\)를 이스케이프 문자로 사용하는 경우 백 슬래시도 Java 이스케이프 문자이기 때문에 Java 문자열 리터럴에 두 개의 백 슬래시 문자를 사용해야합니다.

fn 키워드

이 키워드는 DBMS에서 사용되는 스칼라 함수를 나타냅니다. 예를 들어, SQL 함수 길이 를 사용 하여 문자열의 길이 를 얻을 수 있습니다.

{fn length('Hello World')}

이것은 문자열 'Hello World'의 길이 인 11을 리턴합니다.

전화 키워드

이 키워드는 저장 프로 시저를 호출하는 데 사용됩니다. 예를 들어, IN 매개 변수가 필요한 저장 프로 시저의 경우 다음 구문을 사용하십시오.

{call my_procedure(?)};

IN 매개 변수가 필요하고 OUT 매개 변수를 반환하는 저장 프로 시저의 경우 다음 구문을 사용합니다.

{? = call my_procedure(?)};

oj 키워드

이 키워드는 외부 조인을 나타내는 데 사용됩니다. 구문은 다음과 같습니다-

{oj outer-join}

외부 조인 = 테이블 {LEFT | RIGHT | FULL} OUTERJOIN {table | 검색 조건에 대한 outer-join}. 예를 들면-

String sql = "SELECT Employees 
              FROM {oj ThisTable RIGHT
              OUTER JOIN ThatTable on id = '100'}";
stmt.execute(sql);