Background Image

FORUM

2012.02.19 03:10

트리거 조건문 질문.

조회 수 8709 추천 수 0 댓글 4
?

단축키

Prev이전 문서

Next다음 문서

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

 

 

 
CREATE TRIGGER aupdateb
BEFORE UPDATE on test_aaa
EXECUTE
if obj.idx = 1
update test_bbb set aa= obj.aa where idx = obj.idx

 

이와같은 트리거를 작성하려하는데

 

test_aaa 이란 테이블에서 업데이트가 이루어질떄 idx가 1인 테이블만 업데이트를 하려고하는데..

 

이에대한 쿼리문작성법이 어떻게 되는지 궁금합니다..

  • ?
    cubebridge 2012.02.19 08:30

    안녕하세요.

    큐브리드에 관심을 가져 주셔서 감사합니다. 문의하신 내용에 대하여 조속하게 답변을 드리도록 하겠습니다.

  • ?
    기린종인 2012.02.21 02:05

     답변 언제주시나요... 빨리주셨으면 좋겠는데...ㅠㅠ

     

  • ?
    이용미 2012.02.21 21:11

    안녕하세요. 답변이 늦어 죄송합니다.

     

    요청하신 트리거는 execute와 if 문의 순서를 바꾸어야 정상적으로 수행이 되실 것 입니다. 즉, 아래와 같이 변경해주셔야 합니다.

    create trigger aupdateb

    before update on test_aaa

    if obj.idx=1

    execute

    update test_bbb set aa=obj.aa where idx=obj.idx

     

    위의 트리거를 적용해 보시고, 원하시는 결과가 나오지 않을 경우, 댓글 부탁드립니다.

    감사합니다.

  • ?
    cgkang 2012.02.22 00:46

    idx가 1인 데이터만 변경되고 나머지는 허용하지 않고자 하는걸로 보입니다.

    이 경우에는

    create trigger aupdateb

    before update on test_aaa

    if obj.idx <> 1

    execute reject;

    와 같은 형태가 되는게 맞을듯 하네요.

     

    트리거를 사용하는 경우에는 성능이 떨어질 수 있는데, 특히 여러개 데이터를 한꺼번에 변경해야 하는 경우에는 더 영향을 받습니다.

    성능관점에서는 응용에서 해당 데이터만 변경될 수 있도록 처리해주는게 나을것 같습니다.

     

    만약, idx=1 인 데이터만 특정사용자에게 노출하고 변경하고자 하는 용도라면

    뷰를 만드는것이 좋을것입니다.

    create view t_v as select * from test where idx=1

    과 같은 형태로 만든후 뷰에 질의를 하면 됩니다.

     


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 59
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4464
1176 ADO.net 또는 ODBC에 대한 질문입니다. 12 세스카 2012.03.20 13377
1175 win 2008 (x64)에서 apm으로 큐브리드 연동 질문 1 hwani012 2012.03.16 7666
1174 윈도우용 큐브리드 문의 1 zino 2012.03.13 6355
1173 큐브리드상에서 한글을 깨지지 않고 자르는 방법이 있을까요? 1 file 안지민 2012.03.13 9326
1172 8.2.2 HA 구성 중 네트워크 장애 복귀 시 role 전환 문제 3 freemir 2012.03.09 13431
1171 설치 문의 드립니다. 1 cuins 2012.03.06 7532
1170 php 모듈 관련 문제좀여... 5 눈뜨면아침 2012.03.01 7126
1169 HA 구성 하에서 RO 브로커 연결 시 SELECT 값이 다릅니다. 9 freemir 2012.02.24 22375
1168 server start시 error 발생 관련 3 flypig 2012.02.24 12075
1167 질문입니다. 1 세스카 2012.02.22 7109
1166 큐브리드 매니져에서만 오류메시지가 깨집니다. 1 file 안지민 2012.02.21 9712
» 트리거 조건문 질문. 4 기린종인 2012.02.19 8709
1164 잦은 트랜잭션으로 인한 마스터서버의 다운 문제. 6 노랑배 2012.02.16 14662
1163 ADO.NET 을 비쥬얼 스튜디오에 연결하기... 4 희나람 2012.02.12 11728
1162 브로커 HA 관련 문의 6 freemir 2012.02.10 19670
1161 초기비번 2 file bj 2012.02.10 8616
1160 Java VM is not running 오류 원인? 6 file 강나루소나무 2012.02.10 15658
1159 ADO.NET 드라이버 집합형 데이터 지원 2 소라게 2012.02.09 39855
1158 cubrid install 후 생성되는 demodb 정보에관해 1 강서꽃미남 2012.02.08 40991
1157 password file open error 라고 뜨면서 큐브리드 매니저 접속이 안되요 1 secret 왕꿈틀이 2012.02.08 20
Board Pagination Prev 1 ... 137 138 139 140 141 142 143 144 145 146 ... 200 Next
/ 200

Contact Cubrid

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