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 4272
3956 Redhat 8버전 tls 1.0 에러 9 11시38분 2024.01.30 112
3955 테이블이 어떤 스키마(데이터베이스)에 속해있는지 알 수 있는 방법이 있나요? 3 엘L 2024.01.29 108
3954 테이블 생성시 REUSE_OID 옵션끄기 문의드립니다 1 원샷 2024.01.25 83
3953 큐브리드 DB에 테이블 생성 후, 저장된 데이터 LIKE 조건 안되는 현상입니다. 1 file 하코 2024.01.24 80
3952 실 ip db서버 이중화 관련 질문 1 zexpand 2024.01.18 81
3951 SQLGate for CUBRID (CUBRID v9.3 and later) 폐쇄망 사용법? 1 임소식 2024.01.18 69
3950 큐브리드 파일 읽기 쓰기 문의 1 임소식 2024.01.18 321
3949 CUBRID Manager 윈도우 버전 배포 해주세요. SQLGate for CUBRID 버그가 많아요. 2 도프 2024.01.17 92
3948 Cubird db 접속 문제 1 file 폰호두 2024.01.17 82
3947 Django Cubrid DB Conntection Error 4 thejoin 2024.01.16 90
3946 CUBRID DB 접속 불가 1 file 싸뤼 2024.01.16 75
3945 Cubrid admin localhost 연결 불가 7 file 싸뤼 2024.01.12 135
3944 파티션 테이블 성능 문의 4 file 방글이 2024.01.11 107
3943 트리거 삭제 오류 1 file slqk135 2024.01.08 86
3942 restoredb 시 log 내용 문의 1 file 별하나에 2024.01.08 64
3941 파티션 테이블 대량 DROP 처리 문의 (ibatis) 1 방글이 2024.01.04 73
3940 JAVA SP 에서 addBatch 오류 문의 1 방글이 2024.01.03 76
3939 DB서버 에러로그 1 file leeee 2023.12.27 111
3938 오라클의 SUBSTRB 기능 문의 3 방글이 2023.12.26 101
3937 멀티host상태에서 admin툴 로그인방법 문의합니다 2 file 원샷 2023.12.20 92
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 199 Next
/ 199

Contact Cubrid

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