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
    넵 좋은 답변 감사드립니다 __)

  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views51
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4458
    read more
  3. 질의자동화 등록 오류 관련 문의

    Date2021.07.07 Byots21 Views85
    Read More
  4. SYS_TIME 출력 시 문의사항

    Date2021.07.01 By오렌지 Views147
    Read More
  5. INSERT 문 VALUES 에 SELECT구문 문의

    Date2021.07.01 Bycubrid초보 Views494
    Read More
  6. 맥북에서 큐브리드 매니저 실행 시 Failed to create the Java Virtual Machine.에러

    Date2021.06.30 Byysh Views501
    Read More
  7. oracle_style_empty_string=yes 설정 문의

    Date2021.06.29 Bycubrid초보 Views154
    Read More
  8. 큐브리드 컬럼 길이 문의

    Date2021.06.29 By큐브리드궁금 Views186
    Read More
  9. 날짜 사이 데이터 구하기

    Date2021.06.29 Bycubrid초보 Views313
    Read More
  10. Log 문의

    Date2021.06.25 Byjungsin Views113
    Read More
  11. JAVA VM is not running 오류

    Date2021.06.25 Byjungsin Views896
    Read More
  12. cubrid가 실행이 안됩니다.

    Date2021.06.23 By푸른호랑이 Views247
    Read More
  13. 큐브리드의 테이블 생성일시, 수정일시 등을 확인 할 수 있는 쿼리를 알고싶습니다.

    Date2021.06.22 By풍류인생 Views704
    Read More
  14. 서버에서 broker 에러가 발생합니다.

    Date2021.06.21 By동구리 Views1482
    Read More
  15. iso8601을 cast하려면 어떻게 해야되나요?

    Date2021.06.21 By자등명법등명 Views157
    Read More
  16. 큐브리드 업타임 확인은 어떻게 하나요

    Date2021.06.21 ByJi Views86
    Read More
  17. 파일 업로드 시 생기는 DB 다운

    Date2021.06.14 By오렌지 Views237
    Read More
  18. 혼합형 데이터 정렬 방법

    Date2021.06.14 By큐키 Views265
    Read More
  19. Docker에 설치된 큐브리드에서 cubrid server stop이 안됩니다.

    Date2021.06.13 By새옹지마 Views431
    Read More
  20. VIEW SELECT 오류 (실행오류: -494)

    Date2021.06.11 Bytenbirds Views460
    Read More
  21. 혼합형 데이터 정렬방법

    Date2021.06.11 By큐키 Views85
    Read More
  22. 두 가지 테이블의 컬럼을 검색해서 업데이트 하는 쿼리

    Date2021.06.09 Byots21 Views740
    Read More
Board Pagination Prev 1 ... 23 24 25 26 27 28 29 30 31 32 ... 200 Next
/ 200

Contact Cubrid

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