Background Image

FORUM

?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

안녕하세요. 큐브리드로 개발 중인 시스템 개발자 중 한명입니다.

기존 AS-IS 소스가 존재하여 트리거 부분을 살펴보고 있는데, 아래와 같은 구문이 있어 질문을 드립니다.

아래는 트리거 생성 스크립트 중 일부 입니다. (테이블명은 임의로 변경하였습니다.)

 

CREATE TRIGGER [aaa_trg01]
  PRIORITY 0.00999999977648258
  BEFORE INSERT ON aaa
  EXECUTE AFTER MERGE
INTO             [aaa] [a] ....중략....

 

위에보면 BEFORE INSERT ON 이 있고 아래쪽에 EXECUTE AFTER가 있어 이 트리거에 대한 실행 시점에 대한 혼동이 있습니다.

속성에서 보여지는 Action Time은 AFTER로 나오고 있는데, BEFORE INSERT ON 처럼 생성문에 BEFORE 와 AFTER 가 있다보니 아무래도 찜찜하여 질문을 드립니다.

이렇게 스크립트가 보여지면 속성에 나온대로 AFTER로 동작하는 것인지, 아니면 속성이 잘못나오고 BEFORE로 동작하는 것인지 답변해 주시면 감사하겠습니다.

그리고 BEFORE와 AFTER가 저렇게 있을경우 어떤 것을 의미하는 것인지도 답변해주시면 감사하겠습니다.

 

- 추가

 

설명서를 읽고 있는데 첫번째 BEFORE의 경우 Condition Time(조건절)에 대한 순서의 표현인 것 같은데, 맞나요?

설명서에는 위 처럼 혼용되는 경우가 없어 정확한 판단이 어렵네요.

위 트리거 문에는(이미 AS-IS에 존재하는 트리거입니다) 조건절이 보시는 것처럼 존재하지 않습니다.

그렇다면 BEFORE는 아무런 의미가 없는 건가요? 일단 속성창에서 Condition Time은 아무것도 보이지 않고 있습니다. (SQL gate 큐브리드용을 쓰고 있습니다.)

조건절이 없음에도 저런 스크립트가 가능한지 궁금합니다.

  • ?
    김창휘 2021.05.17 18:02
    안녕하세요.
    큐브리드를 이용해 주셔서 감사합니다.
    확인하신 설명서대로 BEFORE 부분은 트리거의 조건영역과(IF Condition) 실행영역이(EXECUTE) 수행되는 시점을 명시한 부분입니다.
    올려주신 스크립트 상으로는 aaa 테이블에 INSERT 행위가 발생되기 전에 EXECUTE Merge 구문내의 WHERE Condition을 참고하여 True인 경우에 해당 구문을 실행하게 됩니다.
  • ?
    제로미 2021.05.17 18:14
    답변 감사합니다.
    EXECUTE Merge 구문 내 라고 하셨는데 SQL Gate의 속성 창에서 Action Time은 AFTER 라고 나옵니다. 그렇다면 INSERT 후에 실행되는 것이 아닌건지요?
    위 트리거는 Condition 절이 없습니다. 보통 Condition 절이 있는 경우 아래에서 보듯

    CREATE TRIGGER [aaa_trg01]
    PRIORITY 0.00999999977648258
    BEFORE INSERT ON aaa
    IF [obj].[del_yn]<>'Y' <- 이런 식으로 condition 절이 있는 것은 보았습니다.
    EXECUTE AFTER MERGE
    INTO [aaa] [a] ....중략....

    그러면 condition 절이 있다고 판단하여 insert 전에 저 조건을 판단하고 insert 후에 merge를 실행하는 것이라 판단을 합리적으로 하겠는데... 말슴드렸다시피 condition 절이 없어서 질문을 드렸습니다.
    또한, 말씀하신 내용대로 insert 행위가 발생되기 전에 EXECUTE Merge 를 한다고 말씀하셨는데, 그렇다면 그것은 BEFORE의 기능이라는 말인데... 현재 Action Time 은 AFTER라고 나옵니다. 더더욱 이해가 가지 않은 상황인데, 답변자분의 착오가 아니시라면 속성의 Action Time의 AFTER라고 나오는 것은 어떤것일까요?
  • ?
    제로미 2021.05.18 10:01

    아... 다시 확인해보니 condition 절에 BEFORE가 있기때문에 이렇게 답변을 달아주셨군요. 그럼 condition 절은 BEFORE 시점에서 이루어지고 그것이 True일 경우 EXCUTE절을 실행하니 EXCUTE에서 EXECUTE AFTER MERGE의 AFTER가 있기 때문에 insert 후에 해당 구문을 실행하니 속성이 AFTER가 나오는 것인지요? 그렇다면 condition 절이 현재 존재 하지 않으니 AFTER 절로 보는 것이 맞긴 하겠네요. 제가 이해한 것이 맞나요?

  • ?
    changhwee 2021.05.18 10:11
    안녕하세요
    답변에 대해서 회신주신 내용이 맞습니다.
    추가로 헤딩 사항에 대해서 테스트를 공유해 드리면 아래와 같습니다.
    결론을 먼저 전달해드리면 EXECUTE 구문에 AFTER 구문이 명시되어 있으면 INSERT 후에 MERGE 구문을 수행하게 되며, MERGE 구문이 명시되어 있지 않으면 MERGE 구문 수행 후 INSERT 구문을 수행하는 것으로 확인이 됩니다.

    아래의 스크립트로 테스트 진행시 with_trigger 데이터를 초기화(삭제)하고 trigger도 재생성(삭제 후 생성) 하면서 테스트 진행하면 됩니다.

    CREATE TABLE with_trigger (id INT UNIQUE);

    CREATE TABLE trigger_actions (id INT UNIQUE);
    INSERT INTO trigger_actions VALUES (11);

    <실행영역에 AFTER 구문이 명시된 경우>
    CREATE TRIGGER trig_1
    PRIORITY 0.00999999977648258
    BEFORE INSERT ON with_trigger
    EXECUTE AFTER MERGE INTO with_trigger tt USING trigger_actions st on tt.id = st.id
    when matched then update set tt.id = 12;


    csql> CREATE TRIGGER trig_1
    csql> PRIORITY 0.00999999977648258
    csql> BEFORE INSERT ON with_trigger
    csql> EXECUTE AFTER MERGE INTO with_trigger tt USING trigger_actions st on tt.id = st.id
    csql> when matched then update set tt.id = 12;
    Execute OK. (0.001001 sec) Committed.

    1 command(s) successfully processed.
    csql> INSERT INTO with_trigger VALUES (11);
    1 row affected. (0.002015 sec) Committed.

    1 command(s) successfully processed.
    csql> select * from with_trigger;

    === <Result of SELECT Command in Line 1> ===

    id
    =============
    12

    1 row selected. (0.004496 sec) Committed.

    1 command(s) successfully processed.



    <실행영역에 AFTER 구문이 생략된 경우>
    CREATE TRIGGER trig_1
    PRIORITY 0.00999999977648258
    BEFORE INSERT ON with_trigger
    EXECUTE MERGE INTO with_trigger tt USING trigger_actions st on tt.id = st.id
    when matched then update set tt.id = 12;

    <처리결과>
    csql> CREATE TRIGGER trig_1
    csql> PRIORITY 0.00999999977648258
    csql> BEFORE INSERT ON with_trigger
    csql> EXECUTE MERGE INTO with_trigger tt USING trigger_actions st on tt.id = st.id
    csql> when matched then update set tt.id = 12;
    Execute OK. (0.000981 sec) Committed.

    1 command(s) successfully processed.
    csql> INSERT INTO with_trigger VALUES (11);
    1 row affected. (0.001397 sec) Committed.

    1 command(s) successfully processed.
    csql> select * from with_trigger;

    === <Result of SELECT Command in Line 1> ===

    id
    =============
    11

    1 row selected. (0.005391 sec) Committed.

    1 command(s) successfully processed.
  • ?
    제로미 2021.05.18 10:15
    넵 좋은 답변 감사드립니다 __)

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4262
556 공급자는 로컬 컴퓨터에 등록할 수 없습니다 에러메세지 2 file swift 2021.05.14 239
555 큐브리드 cannot connect to a broker 3 솨솨솨 2021.05.14 1217
554 Cubrid 데이터베이스 생성 시 오류 확인 요청 3 file 딤디딤 2021.05.14 164
553 HA 구성 후에 HA-Node Info 에 state ip_addr_mismatch 가 출력됩니다. 1 나래 2021.05.17 146
» 생성 스크립트에 대한 트리거 순서에 대하여 질문 드립니다. 5 제로미 2021.05.17 203
551 가장 어을리는 cubrid version 1 정글의 왕자 2021.05.18 130
550 Failed on handshake between client and server 에러가 계속 발생 합니다.. 3 file dwpark 2021.05.18 176
549 CUBRID 매니저에서 뷰 편집 -> SQL문 보기시 SQL이 너무 길어 짤리는 현상 4 테크 2021.05.24 267
548 큐브리드에서 오프소스 Talend 사용 가능한 지 문의드립니다. 3 본부장 2021.05.24 177
547 에러가 왜 날까요... 잘 입력 되다가 이런 에러가 나네요.. 파이선 사용자입니다. 4 오션나인 2021.05.27 866
546 큐브리드 커맨드 내 spool과 set echo 의 사용가능 여부 1 솨솨솨 2021.06.01 1988
545 .AccessViolationException (C#) 1 swift 2021.06.03 203
544 파라미터 바인드 문제.. 2 오션나인 2021.06.04 254
543 php 7.3 + Cubrid 8.4.4 연동 문제 1 땡땡이 2021.06.08 82
542 두 가지 테이블의 컬럼을 검색해서 업데이트 하는 쿼리 8 ots21 2021.06.09 728
541 혼합형 데이터 정렬방법 1 큐키 2021.06.11 80
540 VIEW SELECT 오류 (실행오류: -494) 2 tenbirds 2021.06.11 459
539 Docker에 설치된 큐브리드에서 cubrid server stop이 안됩니다. 4 새옹지마 2021.06.13 425
538 혼합형 데이터 정렬 방법 1 큐키 2021.06.14 252
537 파일 업로드 시 생기는 DB 다운 7 오렌지 2021.06.14 227
Board Pagination Prev 1 ... 167 168 169 170 171 172 173 174 175 176 ... 199 Next
/ 199

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales