>데이터 베이스 >Oracle >Oracle Java는 저장 프로시저를 호출합니다.

Oracle Java는 저장 프로시저를 호출합니다.

PHPz
PHPz원래의
2023-05-07 19:55:071395검색

Oracle 데이터베이스는 현재 전 세계에서 가장 널리 사용되는 관계형 데이터베이스 관리 시스템이며, Java는 가장 널리 사용되는 프로그래밍 언어 중 하나이며 여러 플랫폼에서 실행될 수 있습니다. 실제 응용에서는 Java와 Oracle을 함께 사용하는 경우가 많기 때문에 Oracle 데이터베이스의 저장 프로시저를 Java로 호출하는 방법을 알아야 합니다.

저장 프로시저는 Oracle 데이터베이스 관리 시스템에서 컴파일하여 데이터베이스에 저장할 수 있는 미리 정의된 SQL 문 집합입니다. 저장 프로시저는 데이터베이스 성능을 향상시키는 데 사용될 수 있으며 다단계 작업을 완료해야 하는 개발자에게 매우 유용한 도구입니다. Java 프로그래머는 저장 프로시저를 호출하여 데이터베이스 작업을 완료할 수 있습니다.

Java 프로그램이 Oracle 저장 프로시저를 호출하는 주요 단계는 다음과 같습니다.

  1. JDBC 드라이버 가져오기

Java 프로그램에서 Oracle 데이터베이스에 연결하려면 JDBC 드라이버를 가져와야 합니다. Oracle은 JDBC 드라이버 oracle.jdbc.driver.OracleDriver를 제공합니다. JDBC 드라이버는 Java 프로그램이 이를 사용하여 데이터베이스 연결을 얻을 수 있도록 Java 프로그램의 클래스 경로로 가져와야 합니다.

  1. 데이터베이스 연결 얻기

Java 프로그램에서는 데이터베이스에 대한 연결을 얻어야 합니다. JDBC에서 제공하는 DriverManager 클래스를 사용하여 데이터베이스에 대한 연결을 얻을 수 있습니다. getConnection 메소드는 데이터베이스에 대한 연결을 얻는 데 사용됩니다. 이를 위해서는 데이터베이스 연결 문자열, 사용자 이름 및 비밀번호가 매개변수로 전달되어야 합니다.

  1. 저장 프로시저를 호출하기 위한 문 준비

Java 프로그램에서는 저장 프로시저를 호출하기 위한 문을 준비해야 합니다. Oracle 데이터베이스에서는 CallableStatement 클래스를 통해 저장 프로시저가 호출됩니다. CallableStatement 클래스는 저장 프로시저 호출을 처리하는 ReadyStatement 클래스의 하위 클래스입니다. 여기에는 저장 프로시저를 호출하는 데 필요한 메서드가 포함되어 있습니다.

  1. 매개변수 바인딩

Java 프로그램에서는 저장 프로시저의 매개변수를 바인딩해야 합니다. CallableStatement 클래스의 setXXX 메소드를 사용하여 매개변수를 저장 프로시저 호출에 바인딩할 수 있습니다. setXXX 메소드의 XXX는 int, String, double 등을 포함하여 메소드에 바인딩된 매개변수 유형을 나타냅니다.

  1. 저장 프로시저 실행

저장 프로시저를 호출하는 문을 준비하고 매개 변수를 바인딩한 후에는 저장 프로시저를 실행할 수 있습니다. Java 프로그램에서는 CallableStatement 클래스의 Execute 메소드나 ExecuteQuery 메소드를 사용하여 저장 프로시저를 실행할 수 있습니다.

  1. 반환 값 처리

저장 프로시저는 커서, 매개변수 값 등과 같은 일부 값을 반환할 수 있습니다. Java 프로그램에서는 저장 프로시저에서 반환된 값을 얻으려면 CallableStatement 클래스의 getXXX 메서드를 사용해야 합니다.

다음은 Oracle 데이터베이스에서 저장 프로시저를 호출하는 방법을 보여주는 샘플 Java 프로그램입니다.

import java.sql.CallableStatement;
import java.sql.DriverManager; sql.Types ;

public class CallPLSQL {

public static void main(String[] args) throws Exception {

// 步骤1:导入JDBC驱动
Class.forName("oracle.jdbc.driver.OracleDriver");

// 步骤2:获取数据库连接
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:ORCL", "user", "password");

// 步骤3:准备调用存储过程的语句
String sql = "{call proc_example(?,?,?)}"; // proc_example是存储过程名
CallableStatement cs = conn.prepareCall(sql);

// 步骤4:绑定参数
cs.setInt(1, 123); // 绑定参数1为整型123
cs.registerOutParameter(2, Types.VARCHAR); // 绑定参数2为字符串类型
cs.registerOutParameter(3, Types.NUMERIC); // 绑定参数3为数字类型

// 步骤5:执行存储过程
cs.execute();

// 步骤6:处理返回值
String strResult = cs.getString(2);// 获取返回值
int iResult = cs.getInt(3);

// 输出返回值
System.out.println("strResult:" + strResult);
System.out.println("iResult:" + iResult);

// 关闭连接和语句
cs.close();
conn.close();

}}


위의 Java 예제 프로그램에서는 proc_example이라는 저장 프로시저를 호출했습니다. 이 저장 프로시저에는 세 개의 매개변수가 있습니다. 첫 번째는 입력 매개변수이고 두 번째와 세 번째는 출력 매개변수입니다. 프로그램은 첫 번째 매개변수를 123에 바인딩하고, RegisterOutParameter 메서드를 사용하여 두 번째 및 세 번째 매개변수의 유형을 바인딩합니다. 프로그램이 저장 프로시저를 실행한 후 getXXX 메소드를 사용하여 저장 프로시저에서 반환된 값을 가져옵니다.

요약

Java 프로그램에서 Oracle 저장 프로시저를 호출하는 것은 매우 유용한 기술입니다. JDBC 드라이버와 CallableStatement 클래스를 사용하면 Oracle 데이터베이스의 저장 프로시저를 쉽게 호출할 수 있습니다. Java 프로그램에서 많은 수의 데이터베이스 작업을 처리해야 하는 경우 저장 프로시저를 호출하는 기술은 매우 유용한 도구가 될 것입니다. 동시에 Java 프로그래머는 Oracle 데이터베이스의 저장 프로시저 구문과 매개변수 바인딩 방법에도 익숙해야 합니다.

위 내용은 Oracle Java는 저장 프로시저를 호출합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.