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
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 65
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4465
839 데이터가져오기] 줄바꿈 데이터 1 ozro 2022.06.07 208
838 큐브리드 포트포워딩 질문입니다.. 2 KunAguero 2019.05.23 207
837 CUBRID_ADO_NET_4_5_10_2_latest.zip 를 적용하였을때 connection 오류 3 file 푸르른하늘 2020.10.13 206
836 큐브리드 매니저 사용시 복구가 안되요 1 file 개발자1 2021.11.05 206
835 union 관련 문의입니다. 2 file Eline 2021.10.26 206
834 파티션 테이블 목록을 조회 할려고 하는데요. 1 Philip Park 2020.03.25 206
833 도커에 설치된 2개의 DB 자동 시작 설정하는 방법 5 새옹지마 2022.06.21 206
832 backupdb 실행 문의 2 file JB 2021.03.02 206
831 모든 테이블의 목록과 각 테이블의 로우 (레코드) 수 확인 4 키롱 2022.12.28 206
830 2가지 질문 드려도 될까요? 볼륨 자동증가 및 아카이브 로그 질문입니다. 4 덴드로비움 2020.11.24 205
829 쿼리 조회오류인가요?? 2 다음 2021.03.11 205
828 group_concat null 질문 1 wndud 2019.08.19 205
827 큐브리드 컬럼 디폴트값 2 백수인 2023.02.06 205
826 테이블/컬럼명 자동완성 설정문의 5 file dfdfdd 2023.02.10 205
825 HA slave applydblog 오류 문의 3 아리별 2021.10.13 204
824 HA 구성 중 슬레이브 재구축 문의 드립니다. 5 file kikiki767 2022.03.25 204
823 10.2 :: round 함수에 버그가 있는 것으로 보입니다. 1 rednuts 2021.02.04 204
» 생성 스크립트에 대한 트리거 순서에 대하여 질문 드립니다. 5 제로미 2021.05.17 204
821 쿼리 오류 (컬럼 조회 순서에 따라 오류) 7 file ozro 2022.08.11 204
820 존재하지 않는 대상조회시 결과값이 나오는 현상 문의 6 file hajun 2021.11.16 203
Board Pagination Prev 1 ... 154 155 156 157 158 159 160 161 162 163 ... 200 Next
/ 200

Contact Cubrid

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