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 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3993 db에 저장되어 있는 CLOB 데이터의 위치가 어디로 저장되는지 확인하는 방법이 있을까요? 1 자바천재 2024.04.25 17
3992 큐브리드 서비스 시작이 안됩니다. 1 file 황남빵 2024.04.24 24
3991 큐브리드 JDBC 드라이버 XA문의 및 큐브리드 분산트랜잭션(XA) 지원 문의 1 몽키스패너 2024.04.24 23
3990 group_concat 변수 리턴 관련... 1 썬더기 2024.04.22 23
3989 기 DB에서 테이블 정보만 가져와서 다른 DB에 생성 1 바다소금 2024.04.22 18
3988 큐브리드 매니저 속도 문의 1 연동테스트용 2024.04.22 14
3987 cubrid count 속 2 kanin 2024.04.19 28
3986 cubrid 10.1 데이터 덮어쓰기 질문입니다. 4 ysk96 2024.04.18 53
3985 ACTION 명령어? 예약어? 1 투투투투기기 2024.04.17 20
3984 sql 구문 사용시 데이터 타입 decimal일 경우 1 투투투투기기 2024.04.11 30
3983 Regexp_count 4 SEO 2024.04.09 66
3982 큐브리드 메모리 오류 관련 질문 2 file 뚜벅뚜벅 2024.04.09 66
3981 큐브리드 실행이 안되는 이슈 1 file 최현욱 2024.04.09 41
3980 unloaddb & loaddb 관련 질문이 있습니다. 1 543534512 2024.04.06 46
3979 mac m1 다운로드 오류 1 file 혜주냉면 2024.04.05 42
3978 list 함수로 만든 sequence type을 varchar로 변환 문의 1 플레이어블 2024.04.04 36
3977 DECODE, CASE WHEN 사용법 문의 2 핑크팬더 2024.04.03 55
3976 schema 파일 loaddb - 스키마 정보 중복오류 문의 4 daay 2024.03.21 91
3975 object to string 4 네오랜덤 2024.03.20 69
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