트리거 질문 드립니다.. 너무 안되서 이렇게 질문 올려요 ㅠ

by 덴드로비움 posted Oct 24, 2017
* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 64bit
CUBRID Ver.
[9.3.9]
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------



오라클 에서 큐브리드로 전환 준비 중입니다. 트리거거 가 전환이 잘안되요 ㅠ 생성이 안됩니다.....

            

기존   ORACLE 트리거 (간략하게 변형했습니다.)                                                  

큐브리드로 전환... 중..
CRATE OR REPLACE TRIGGER tr_aaa

AFTER INSERT ON tb_aaa
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
DECLARE
 ddd number;                           -->  질문1. 큐브리드에서는 변수 지정 안되나요?
BEGIN
 IF :NEW. a2 = '0' THEN      --->  질문2. 큐브리드는 IF THEN 분기와 ELSEIF 가  안되나요?
 INSERT INTO tb_bbb (b1, b2, bcode) VALUES (b_seq.NEXTVAL, :NEW.a2, '사과코드');
  
   ELSIF :NEW.a2= '1' THEN
   SELECT c_seq.NEXTVAL INTO ddd FROM dual;     ----> 변수 지정에서 활용 하려면??
   INSERT INTO tb_ccc (c1, c2) VALUES (ddd, :NEW.a2);
  
   INSERT INTO tb_bbb (b1, b2, bcode) VALUES (ddd, :NEW.a2, '딸기코드');
  
   END if;            
end;  

질문3. tb_aaa 인서트가 일어날시 tb_bbb와 tb_ccc에 인서트 하고 싶은데 하나의 트리거

안에서는한번만 EXECUTE 문을 사용 할수 바께 없나요? 만약 그렇다면 트리거를 2,3 개

만들어서  처리 해야 가능한가요?

별수 없이 잘안되서 트리거를 2개로 만들어서 쪼개서 하면 여기까진 됨...

CREATE  TRIGGER tr_aaa
AFTER INSERT ON tb_aaa

 IF a2 = '0'
 EXECUTE
 INSERT INTO tb_bbb (b1, b2, bcode) VALUES (b_seq.NEXTVAL, a2, '사과코드');


CREATE  TRIGGER tr_bbb
AFTER INSERT ON tb_aaa  
   IF a2= '1'
   EXECUTE 
   INSERT INTO tb_bbb (b1, b2, bcode) VALUES (b_seq.NEXTVAL, 'a2', '딸기코드');

----------------------------------------------------------------------------------------------------

<------최종적으 오라클에서 처럼 하나의 트리거 안에서

변수를 선언해여러 이벤트를 한번에 처리 하고 싶은데... 방법이 없을까요?
--------------------------------------------------------------------------------------------------- 

--->  질문4. 아래 NEW  구분에서 오류 나는데 INSERT시는 사용하는게 아닌가요?

CREATE  TRIGGER tr_aaa
AFTER INSERT ON tb_aaa

 IF new.a2 = '0'
 EXECUTE
 INSERT INTO tb_bbb (b1, b2, bcode) VALUES (b_seq.NEXTVAL, new.a2, '사과코드');


쓰다보니... 길어 지네요.... ㅜ

테스트 하기 위해 생성했던 큐브리드 테이블 ddl 입니다....


DROP TABLE tb_aaa;

CREATE TABLE [tb_aaa] (
 [a1] NUMERIC(10)  NOT NULL,
 [a2] CHARACTER VARYING (40)  ,
 CONSTRAINT [pk_a1] PRIMARY KEY([a1])
);

DROP TABLE tb_bbb;

CREATE TABLE [tb_bbb] (
 [b1] NUMERIC(10)  NOT NULL,
 [b2] CHARACTER VARYING (40)  ,
 [bcode]CHARACTER VARYING (40)  ,
 CONSTRAINT [pk_b1] PRIMARY KEY([b1])
);

DROP TABLE tb_ccc;

CREATE TABLE [tb_ccc] (
 [c1] NUMERIC(10)  NOT NULL,
 [c2] CHARACTER VARYING (40)  ,
 CONSTRAINT [pk_c1] PRIMARY KEY([c1])
);

create SERIAL b_seq
START WITH 1 INCREMENT BY 1 MINVALUE 0 NOMAXVALUE NOCYCLE NOCACHE


create SERIAL c_seq
START WITH 1 INCREMENT BY 1 MINVALUE 0 NOMAXVALUE NOCYCLE NOCACHE


Articles

1 2 3 4 5 6 7 8 9 10