> 데이터 베이스 > Oracle > Oracle 데이터베이스에서 열 값을 수정하는 방법

Oracle 데이터베이스에서 열 값을 수정하는 방법

PHPz
풀어 주다: 2023-04-04 09:28:03
원래의
3257명이 탐색했습니다.

Oracle 데이터베이스는 세계에서 가장 일반적으로 사용되는 관계형 데이터베이스 관리 시스템 중 하나입니다. Oracle 데이터베이스를 운영하고 유지 관리할 때 비즈니스 논리 요구 사항을 충족하기 위해 테이블의 열을 수정해야 하는 경우가 많습니다. 본 글에서는 독자들의 참고를 위해 오라클 데이터베이스에서 컬럼 값을 수정하는 방법을 자세히 소개하겠습니다.

1. UPDATE 문을 사용하여 열 값 수정 ​​

UPDATE 문은 Oracle 데이터베이스에서 데이터를 수정하는 데 가장 일반적으로 사용되는 방법 중 하나입니다. UPDATE 문은 테이블의 열 값을 쉽게 수정할 수 있습니다. 기본 구문은 다음과 같습니다.

UPDATE table_name
SET 컬럼1 = value1, 컬럼2 = 값2,...
WHERE 조건;

이 중 table_name은 수정해야 할 테이블의 이름을 나타내며, 등은 수정해야 할 열 이름을 나타내고, value1, value2 등은 수정해야 하는 값을 나타내고, Condition은 데이터 수정 조건을 나타냅니다.

다음은 테이블에서 직원 이름이 "Zhang San"인 레코드의 위치를 ​​"Programmer"에서 "Software Engineer"로 변경해야 한다고 가정합니다.

UPDATE Employee_table
SET position = 'Software Engineer'
WHERE name = 'Zhang San';

2. PL/SQL 문 블록을 사용하여 열 값을 수정합니다.

UPDATE 문을 사용하는 것 외에도 PL/을 사용할 수도 있습니다. 테이블 수정을 구현하기 위한 SQL 문 블록 열 값 수정. PL/SQL은 Oracle 데이터베이스 전용 절차적 언어로, 구문은 다른 프로그래밍 언어와 유사하며 저장 프로시저, 트리거, 함수 등을 작성하는 데 사용할 수 있습니다.

다음은 직원 테이블의 모든 급여를 500위안씩 인상해야 한다고 가정합니다. 이를 달성하기 위해 다음 PL/SQL 문 블록을 사용할 수 있습니다.

DECLARE
v_increase_salary NUMBER(10,2) := 500;
BEGIN
FOR emp IN (SELECT * FROM Employee_table)
LOOP

UPDATE employee_table
SET salary = emp.salary + v_increase_salary
WHERE id = emp.id;
로그인 후 복사

END LOOP;
COMMIT;
END;

위의 예에서는 먼저 v_increase_salary 변수를 정의하여 필요한 급여 값을 저장합니다. 증가했습니다. 그런 다음 FOR 루프를 사용하여 모든 직원 기록을 탐색하고 UPDATE 문을 통해 급여 값을 500위안씩 늘립니다. 마지막으로 COMMIT 문을 통해 수정 결과를 제출한다.

3. TRIGGER를 사용하여 열 값 수정 ​​

TRIGGER는 Oracle 데이터베이스에서 매우 일반적으로 사용되는 개체이며 특정 작업을 자동으로 수행하는 데 사용할 수 있습니다. 테이블에 TRIGGER를 생성함으로써 컬럼의 값을 수정하는 등 데이터 작업이 발생할 때 관련 작업을 자동으로 수행할 수 있습니다. 구체적인 작업 방법은 다음과 같습니다.

CREATE OR REPLACE TRIGGER Trigger_name
AFTER INSERT OR UPDATE OR DELETE
ON table_name
FOR EACH ROW
BEGIN
-- Trigger_body
-- 테이블에 지정된 열의 값을 수정하고 기타 Operations
END;

그 중 table_name은 TRIGGER가 생성되어야 하는 테이블의 이름을 나타내며, Trigger_name은 TRIGGER의 이름을 나타내며, AFTER INSERT OR UPDATE OR DELETE는 TRIGGER가 트리거된다는 것을 나타냅니다. INSERT, UPDATE 또는 DELETE 작업을 수행할 때 FOR EACH ROW는 쌍을 나타냅니다. 레코드의 각 행은 TRIGGER를 트리거할 때 수행해야 하는 특정 작업을 나타냅니다.

다음은 직원 테이블에 트리거를 추가하여 직원 급여 내역 테이블에 수정 전 급여 값을 기록해야 한다고 가정합니다. 해당 트리거를 생성합니다:

트리거 생성 또는 교체 trg_save_salary
직원 테이블에 대한 업데이트
각 행에 대해
BEGIN
INSERT INTO Salary_history_table(emp_id, old_salary, new_salary, update_date)
VALUES(:OLD.id, :OLD .s 알라리, : NEW.salary, SYSDATE);
END;

위의 예에서는 Employee_table 테이블에서 UPDATE 작업이 발생할 때 트리거되는 trg_save_salary라는 TRIGGER를 생성했습니다. INSERT INTO 문을 통해 Salal_history_table 테이블에 수정 전 급여를 기록하고, 기타 관련 정보(사원 ID, 기존 급여 값, 새 급여 값, 수정 날짜)를 함께 기록합니다.

요약:

Oracle 데이터베이스는 세계에서 가장 일반적으로 사용되는 관계형 데이터베이스 관리 시스템 중 하나입니다. UPDATE 문, PL/SQL 문 블록 및 TRIGGER의 사용을 익히면 테이블의 열 값을 수정할 수 있습니다. 비즈니스 요구 사항을 충족합니다. 실제 애플리케이션에서는 최적의 운영 및 유지 관리 효과를 달성하기 위해 다양한 비즈니스 시나리오에 따라 다양한 수정 방법을 선택해야 합니다.

위 내용은 Oracle 데이터베이스에서 열 값을 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿