> 데이터 베이스 > MySQL 튜토리얼 > ORACLE数据库中ID自增的设置

ORACLE数据库中ID自增的设置

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 15:18:49
원래의
1315명이 탐색했습니다.

我本来是要把SQLSERVER中的数据迁移到ORACLE的,没想到迁移之后,程序就出错,无法插入NULL,很容易就想到因为两者的ID自增机制是不同的,直接迁移过来会出问题。在SQLSERVER中要字段自增非常简单,标识下点上自增就可以了。但是在ORACLE里面没有这么简单,

        我本来是要把SQLSERVER中的数据迁移到ORACLE的,没想到迁移之后,程序就出错,无法插入NULL值,很容易就想到因为两者的ID自增机制是不同的,直接迁移过来会出问题。在SQLSERVER中要字段自增非常简单,标识下点上自增就可以了。但是在ORACLE里面没有这么简单,还没有想通到底因为什么,ORACLE要把经常用到的自增字段分成序列(SEQUENCE)触发器(TRIGGER )来实现,如果有大神知道其中的细节和好处,请不吝赐教。

        因为我的表是已经存在的,所有只需要上述说的两步,建立序列和触发器

        1.建立序列

CREATE SEQUENCE sq_log

INCREMENT BY 1 -- 每次加几个

START WITH 700 -- 迁移过来的,已经有记录了

MINVALUE 1      --最小值1

NOMAXVALUE -- 不设置最大值

NOCYCLE -- 一直累加,不循环

NOCACHE -- 不建缓冲区
로그인 후 복사

2.建立触发器

    CREATE  TRIGGER tri_log

    BEFORE

    INSERT ON DBLOG

    FOR EACH ROW

    BEGIN

        SELECT sq_log.nextval into :new.logid  from dual;

    END tri_log;
로그인 후 복사



        


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