>데이터 베이스 >MySQL 튜토리얼 >자바 mysql 저장 프로시저

자바 mysql 저장 프로시저

王林
王林원래의
2023-05-20 13:37:08813검색

Java와 MySQL은 널리 사용되는 두 가지 기술입니다. 이를 사용할 때 데이터를 처리하기 위해 저장 프로시저를 사용해야 하는 경우가 많습니다. 저장 프로시저는 특정 작업을 수행하는 데 필요할 때 호출할 수 있는 데이터베이스에 정의된 재사용 가능한 코드 블록입니다. 이 기사에서는 Java 및 MySQL의 저장 프로시저를 생성하고 호출하는 방법을 소개합니다.

1. MySQL 저장 프로시저란 무엇입니까?

MySQL에서 저장 프로시저는 특정 논리적 순서로 결합되어 재사용 가능하고 실행 가능한 프로세스를 형성하는 미리 정의된 SQL 문 집합입니다. 저장 프로시저는 복잡한 비즈니스 논리를 처리하거나 데이터에 대한 일괄 작업을 수행하는 데 자주 사용됩니다. 일반 SQL 문과 달리 저장 프로시저는 매개 변수를 받아들이고 데이터를 반환할 수 있으므로 복잡한 비즈니스 논리를 처리할 때 저장 프로시저를 더욱 유연하고 효율적으로 만듭니다.

2. MySQL 저장 프로시저를 만드는 방법

MySQL에서는 CREATE PROCEDURE 문을 사용하여 저장 프로시저를 만들 수 있습니다. CREATE PROCEDURE 문의 기본 구문은 다음과 같습니다.

CREATE PROCEDURE procedure_name ([IN | OUT | INOUT] parameter_name data_type[, ...])
BEGIN
    -- 存储过程的SQL语句块
END

그 중 프로시저_이름은 저장 프로시저의 이름, 매개변수_이름은 저장 프로시저의 매개변수 이름, 데이터_유형은 매개변수의 데이터 유형입니다. 저장 프로시저의 SQL 문 블록은 BEGIN과 END 사이에 위치합니다.

다음은 원의 원주와 면적을 계산하는 저장 프로시저를 만드는 방법을 보여주는 간단한 예입니다.

CREATE PROCEDURE calc_circle(IN r INT, OUT circumference FLOAT, OUT area FLOAT)
BEGIN
    SET circumference = 2 * PI() * r;
    SET area = PI() * r * r;
END

이 저장 프로시저는 r이라는 정수 매개 변수를 허용하고 원의 원주와 면적을 반환합니다. . 저장 프로시저에서는 MySQL에 내장된 PI() 함수를 사용하여 pi를 계산합니다. 원주와 면적은 각각 둘레와 면적의 출력 매개변수입니다. 해당 값을 해당 계산 결과로 설정하기 위해 SET 문을 사용합니다.

3. MySQL 저장 프로시저 호출 방법

MySQL에서 저장 프로시저를 생성하면 Java에서 호출할 수 있습니다. JDBC(Java Database Connectivity) 기술을 사용하여 MySQL 데이터베이스에 연결하고 미리 컴파일된 명령문을 사용하여 저장 프로시저를 호출할 수 있습니다. 다음은 방금 생성한 calc_circle 저장 프로시저를 호출하는 방법을 보여주는 기본 Java 코드 예제입니다.

import java.sql.*;

public class CallSPDemo {
    public static void main(String[] args) {
        Connection conn = null;
        CallableStatement cs = null;
        
        try {
            // 连接MySQL数据库
            String url = "jdbc:mysql://localhost:3306/test";
            String user = "root";
            String password = "123456";
            conn = DriverManager.getConnection(url, user, password);
            
            // 创建CallableStatement对象
            String sp = "{CALL calc_circle(?, ?, ?)}";
            cs = conn.prepareCall(sp);
            
            // 设置输入参数
            cs.setInt(1, 5);
            
            // 设置输出参数类型
            cs.registerOutParameter(2, Types.FLOAT);
            cs.registerOutParameter(3, Types.FLOAT);
            
            // 执行存储过程
            cs.execute();
            
            // 获取输出参数值
            float circum = cs.getFloat(2);
            float area = cs.getFloat(3);
            
            // 输出结果
            System.out.println("Circumference: " + circum);
            System.out.println("Area: " + area);
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (cs != null) cs.close();
                if (conn != null) conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

코드에서는 java.sql 패키지의 Connection 및 CallableStatement 클래스를 사용하여 MySQL 데이터베이스에 연결하고 저장된 프로시저를 호출합니다. 절차. main() 메소드에서는 먼저 Connection 객체와 CallableStatement 객체를 정의합니다. 그런 다음 MySQL 데이터베이스에 연결하고 prepareCall() 메서드를 통해 CallableStatement 객체를 생성했습니다. CallableStatement 객체를 생성할 때 저장 프로시저 이름과 매개변수를 정의하기 위해 저장 프로시저를 생성할 때와 동일한 구문을 사용합니다.

다음으로 setInt() 메서드를 통해 저장 프로시저의 입력 매개변수 r 값을 5로 설정합니다. 그런 다음, RegisterOutParameter() 메소드를 사용하여 결과 세트의 출력 매개변수 유형을 정의합니다. 여기서는 FLOAT 유형입니다. 마지막으로, Execute() 메소드를 사용하여 저장 프로시저를 실행하고 getFloat() 메소드를 사용하여 출력 매개변수의 값을 가져옵니다. 출력 매개변수의 값을 가져오기 전에 저장 프로시저를 실행해야 합니다.

마지막으로 계산된 원의 원주와 면적을 출력합니다.

4. 저장 프로시저의 장점

MySQL 저장 프로시저를 사용하면 비즈니스 로직을 데이터베이스 작업과 분리하고 코드를 재사용할 수 있다는 장점이 있습니다. 또한 저장 프로시저는 데이터베이스 성능과 보안도 향상시킬 수 있습니다.

먼저 저장 프로시저는 실행 시 미리 컴파일되어 서버에 캐시되므로 실행 속도가 빨라지므로 데이터베이스 성능을 향상시킬 수 있습니다. 또한 저장 프로시저를 사용하면 여러 데이터베이스 작업을 병합할 수 있으므로 데이터베이스 연결 및 연결 해제 횟수가 줄어들고 데이터베이스 성능이 크게 향상됩니다.

둘째, 저장 프로시저를 통해 데이터베이스의 데이터 액세스를 제어할 수 있어 데이터베이스 보안이 향상됩니다. 예를 들어 특정 민감한 데이터 테이블에 대한 액세스를 제한하고 권한이 있는 사용자만 해당 테이블에 액세스하기 위해 저장 프로시저를 실행하도록 허용할 수 있습니다.

요약하자면, MySQL 저장 프로시저는 데이터를 더 잘 처리하고 관리할 수 있게 해주는 매우 유용한 기술입니다. 저장 프로시저의 사용법을 배우고 숙달함으로써 데이터베이스 개발 및 유지 관리 기능을 향상시켜 비즈니스 요구 사항을 더 잘 충족할 수 있습니다.

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

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