> 데이터 베이스 > MySQL 튜토리얼 > Oracle 데이터베이스의 기존 열에 자동 증가 기능을 어떻게 추가할 수 있습니까?

Oracle 데이터베이스의 기존 열에 자동 증가 기능을 어떻게 추가할 수 있습니까?

DDD
풀어 주다: 2024-12-26 09:46:10
원래의
555명이 탐색했습니다.

How Can I Add Auto-Incrementing Functionality to Existing Columns in Oracle Databases?

Oracle 데이터베이스에서 기존 열 자동 증가

Oracle의 기존 열에 자동 증가 기능을 추가하는 방법은 다음과 같습니다. Oracle 버전에서.

Oracle 12c 이상: 사용 ID 열

Oracle 12c에서는 자동 증가를 단순화하는 IDENTITY 열 기능을 도입했습니다.

CREATE TABLE t (
ID NUMBER GENERATED ALWAYS AS IDENTITY START WITH 150111111 INCREMENT BY 1,
text VARCHAR2(50)
);
로그인 후 복사

Oracle 11g 및 이전 버전: 시퀀스 및 트리거

12c 이전 Oracle 버전의 경우 시퀀스 조합을 사용할 수 있습니다. 및 트리거:

  1. 시퀀스 생성:
CREATE SEQUENCE t_seq START WITH 150111111 INCREMENT BY 1;
로그인 후 복사
  1. 테이블 변경 및 기본 추가 키:
ALTER TABLE t ADD CONSTRAINT id_pk PRIMARY KEY (ID);
로그인 후 복사
  1. 트리거 만들기:
CREATE OR REPLACE TRIGGER t_trg
BEFORE INSERT ON t
FOR EACH ROW
WHEN (new.id IS NULL)
BEGIN
SELECT t_seq.NEXTVAL INTO :new.id FROM dual;
END;
로그인 후 복사

이 트리거는 ID 열에 값을 자동으로 채웁니다. 시퀀스에서.

예 사용법:

두 방법 모두 삽입은 150111111부터 시작하는 자동 증가 값으로 ID 열을 채웁니다.

INSERT INTO t(text) VALUES('auto-increment test');
로그인 후 복사

테이블을 쿼리하면 자동 증가 값이 확인됩니다. ID:

SELECT * FROM t;

ID                        TEXT
------------------------- ----------------------------------------
150111111 This table has an auto-incrementing column
로그인 후 복사

참고: Oracle은 ID 열을 사용할 때 ISEQ$$라는 시퀀스를 암시적으로 생성합니다.

위 내용은 Oracle 데이터베이스의 기존 열에 자동 증가 기능을 어떻게 추가할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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