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 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3974 /home/jenkins/workspace/cubrid_release_10.1/src/transaction/boot_cl.c, line 1138 CODE = -971 Tran = -1, EID = 1Program 'tranlist' (pid ) connected to database server 'test' on the host 'localhost' 4 jmkim 2023.03.13 196
3973 0.5 이하 반올림 함수가 어떻게 되나요? 4 coolbyj 2009.10.22 21273
3972 0으로 나눌수가 없는 경우.. 처리를 위해서 디코더나 case를 사용해서 써봤는데 1 거만고양이 2015.04.01 4253
3971 10.1 ==> 10.2 버전 업그레이드를 준비 중인데요. 1 Philip Park 2020.03.26 110
3970 10.1 또는 10.2. 버전에서는 web manager를 지원 안 하나요? 1 hbg 2020.01.10 141
3969 10.1 버전의 jdbc 드라이버로 9.3 버전 접속이 되는지요? 2 coolbyj 2020.09.11 212
3968 10.2 :: jdbc 버그? :: decimal 컬럼에 무조건 정수로 저장되는 상황 발생 1 rednuts 2021.02.06 410
3967 10.2 :: round 함수에 버그가 있는 것으로 보입니다. 1 rednuts 2021.02.04 204
3966 10월 10일날 삭제되어 버린 일부 데이터 복구를 하고 싶습니다. 1 나무친구 2017.10.16 694
3965 11.2 jdbc driver 1 경산손사장 2022.06.09 237
3964 11.2 path 방법 문의 4 리들러 2022.08.09 99
3963 11.2버전에서 사용자 스키마에 대해서 궁금한 것이 있습니다. 1 로키 2023.11.08 138
3962 11버전 설치 후에 cub_auto 프로세스가 보이지가 않습니다. 1 kikiki767 2022.02.02 74
3961 13개 이상 AVG 혹은 SUM 사용 시 결과로 Null 값만 나옵니다. 2 oiuy 2015.04.10 7235
3960 1623글 답변 확인 부탁드립니다. 1 토네이도 2013.09.16 7865
3959 1895번 추가 문의 드립니다 1 dgr 2014.07.16 4774
3958 1MB 넘는 데이터 문자열 붙일때 오류 1 빛날구름 2015.08.04 5439
3957 1대의 서버에 다른 버젼의 큐브리드 추가 설치..실행시 에러에 대해 문의드립니다. 1 S1000RR 2014.08.08 7695
3956 1대의 서버에 버젼이 다른 cubrid를 설치하려고 합니다. 1 secret 어려운큐브 2011.11.03 14
3955 2.0에서 2.1로 업그레이드 하려면? 1 초보 2010.02.04 9803
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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