>데이터 베이스 >Oracle >Oracle을 일괄 수정하는 방법

Oracle을 일괄 수정하는 방법

PHPz
PHPz원래의
2023-04-18 15:19:195802검색

Oracle은 세계에서 가장 유명하고 인기 있는 데이터베이스 관리 시스템 중 하나입니다. 대용량 데이터를 처리할 수 있으며 높은 확장성과 유연성을 제공합니다. Oracle은 또한 많은 강력한 도구와 기능을 제공하므로 엔터프라이즈 수준 데이터 관리를 위한 첫 번째 선택이 됩니다. Oracle에서는 SQL 문을 사용하여 데이터를 쿼리, 업데이트, 삽입 및 삭제할 수 있습니다. 그러나 동시에 많은 양의 데이터를 수정하려는 경우 수동으로 하나씩 변경하는 것은 당연히 최선의 선택이 아닙니다. 이 문서에서는 Oracle의 도구와 구문을 사용하여 일괄적으로 데이터를 수정하는 방법을 소개합니다.

1. SQL UPDATE 문을 사용하여 일괄 업데이트합니다.

SQL UPDATE 문을 사용하여 일괄 업데이트합니다. 일반적인 구문은 다음과 같습니다.

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

그 중 table_name은 업데이트할 테이블 이름, column1, column2 등은 업데이트할 열 이름, value1, value2는 업데이트할 값입니다. 조건은 업데이트 조건입니다.

예를 들어, 학생 이름과 점수라는 두 개의 열이 포함된 학생이라는 테이블이 있습니다. 이제 점수를 10포인트 늘리려면 다음 SQL 문을 사용할 수 있습니다.

UPDATE students
SET score = score + 10;

이 문은 테이블에 있는 모든 레코드의 점수 열 값을 10포인트씩 증가시킵니다.

하지만 특정 학생의 점수만 업데이트하고 싶다면 어떻게 해야 할까요? 이때 WHERE 절을 사용하여 업데이트 조건을 지정할 수 있습니다. 예:

UPDATE students
SET score = score + 10
WHERE name = '张三';

이 명령문은 "Zhang San"이라는 학생의 점수만 업데이트합니다.

SQL UPDATE 문을 사용하여 일괄적으로 데이터를 업데이트하는 가장 기본적인 방법입니다.

2. Oracle의 PL/SQL 문을 사용하여 일괄적으로 데이터 업데이트

SQL UPDATE 문을 사용하는 것 외에도 Oracle의 PL/SQL 문을 사용하여 일괄적으로 데이터를 업데이트할 수도 있습니다. 이 접근 방식은 일반적으로 보다 복잡한 데이터 업데이트 상황에 적합합니다.

다음은 PL/SQL 문을 사용하여 일괄적으로 데이터를 업데이트하는 예입니다. 직원 이름, 급여, 업무 부서라는 세 개의 열이 포함된 직원이라는 테이블이 있다고 가정합니다. 이제 "영업" 부서의 모든 직원의 급여를 10% 인상하려고 합니다. 이는 특정 조건에 따른 데이터 수정이므로 SQL UPDATE 문보다 PL/SQL 문을 사용하는 것이 더 적합합니다.

DECLARE
    CURSOR c_sales_employees IS
    SELECT emp_id, salary FROM employees WHERE department = 'sale';

    v_emp_id employees.emp_id%TYPE;
    v_salary employees.salary%TYPE;
BEGIN
    FOR emp IN c_sales_employees LOOP
        v_emp_id := emp.emp_id;
        v_salary := emp.salary * 1.1;
        UPDATE employees SET salary = v_salary WHERE emp_id = v_emp_id;
    END LOOP;
    COMMIT;
END;

위 코드에서는 "Sales" 부서의 직원 정보를 저장하는 데 사용되는 CURSOR 유형 변수 c_sales_employees가 먼저 정의됩니다. 그런 다음 FOR 루프를 사용하여 c_sales_employees의 모든 직원 이름과 급여를 v_emp_id 및 v_salary에 저장하고 UPDATE 문을 사용하여 해당 직원 급여를 수정합니다. 마지막으로 COMMIT 문을 사용하여 트랜잭션을 커밋합니다.

3. Oracle의 일괄 수정 도구를 사용하세요

Oracle에는 데이터를 일괄 수정하는 데 사용할 수 있는 몇 가지 기본 제공 도구도 있습니다. 이러한 도구를 사용하면 대량의 데이터를 더 빠르고 안전하게 처리할 수 있습니다. 다음은 두 가지 주요 도구에 대한 소개입니다.

  1. SQL*Loader

SQL*Loader를 사용하여 데이터 파일을 Oracle 데이터베이스에 일괄 로드하려면 다음 단계를 따라야 합니다.

  1. 컨트롤 만들기 파일.
  2. 가져올 데이터 파일을 준비하세요.
  3. SQL*Loader를 실행하고 컨트롤 파일과 데이터 파일을 지정합니다.

다음은 학생 성적 정보를 Oracle로 가져오기 위한 간단한 제어 파일 예입니다.

LOAD DATA
INFILE 'student_grades.csv'
APPEND INTO TABLE student_grades
FIELDS TERMINATED BY "," (name, id, grade);

이 파일에는 가져올 데이터 파일이 Student_grades.csv이고, 그 안에 있는 데이터가 쉼표입니다. 구분 기호는 각각 학생 이름, 학생 ID 및 학생 점수를 나타내는 세 개의 열로 구분됩니다.

  1. Oracle SQL Developer

Oracle SQL Developer는 Oracle 데이터베이스의 데이터를 관리하는 데 사용할 수 있는 그래픽 인터페이스 기반 도구입니다. SQL Developer를 사용하면 데이터를 대량으로 수정하는 것이 더 쉽습니다.

다음은 SQL Developer를 사용하여 데이터를 일괄 수정하는 단계입니다.

  1. 수정해야 할 Oracle 데이터베이스에 연결합니다.
  2. 왼쪽 탐색 모음에서 데이터 테이블을 찾고 수정해야 할 데이터 열을 찾으세요.
  3. 수정하려는 열 또는 모든 열을 선택하고 마우스 오른쪽 버튼을 클릭하여 행 편집 창을 엽니다.
  4. 필요에 따라 데이터를 변경하고 수정 사항을 저장하세요.

요약

일괄 수정은 오라클 데이터베이스 관리의 핵심 작업 중 하나입니다. 이 문서에서는 SQL UPDATE 문과 PL/SQL 문을 사용하여 일괄적으로 데이터를 업데이트하는 방법과 Oracle의 일괄 수정 도구를 사용하여 대량의 데이터를 처리하는 방법을 소개합니다. 이러한 팁은 데이터베이스 관리자가 Oracle 데이터베이스의 데이터를 보다 효율적이고 정확하게 관리하는 데 도움이 될 수 있습니다.

위 내용은 Oracle을 일괄 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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