Background Image
2010.10.07 06:44

cubrid 3.0 버그.

조회 수 12369 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

 버그 발생 단계

   1. 트리거 생성

       생성 쿼리문 :  CREATE TRIGGER "1"
AFTER STATEMENT INSERT ON "code"
EXECUTE INVALIDATE TRANSACTION;

  2. 해당 테이블 code 를 동일하게 생성 ( 동일 구조 테이블 추가 )

     1. 조회.   select * from "code";

     2. 결과 .

                        X Mixed
                       W Woman
                       M Man
                       B Bronze
                       S Silver
                       G Gold
   3. 동일구조의 테이블 생성 ( code_bk )

      1. 자료 입력

               insert into code_bk
               select * from "code";

       2. code 테이블 자료 삭제

                delete from code ;

       3. code 의 테이블에 code_bk 의 자료 입력

               오류 내역 (자세한 사항은 첨부 이미지 확인 )

               내용 : " 질의 오류가 있습니다. 오류 내용은 아래와 같습니다. 계속하시겠습니까?

                              실행 오류 : -529

                              4번째 라인 실행 오류

                           

                              오류 설명 :

                                Transaction cannot be committed, it was invalidated by trigger "i". "

                  이상입니다.

 

            

 

 

  • ?
    Conpu 2010.10.08 01:13

    우선 CUBRID에 대한 관심 감사드립니다. 두 가지 사항으로 나누어 질문에 대하여 답변을 드리도록 하겠습니다.

     

    1. code테이블에 대해 생성한 인서트 제약 트리거가 복제되지 않는 오류가 발생한다.

    Create table like는 해당 트리거까지 복사해주는 것은 아니며, 컬럼과 인덱스를 복사해주는 것이므로 버그가 아니며, 스펙입니다.
    트리거 객체는 테이블과 연관되어 있기는 하지만 별개의 스키마 객체로 보고 있으며, 복사 과정에서 트리거 이름을 자동 부여해야 하는데 이는 DBA가 원하는 바가 아닐 수 있습니다.
    즉 create table like로 테이블 스키마 복사할 때에 트리거를 옮기고 싶으시다면 사용자가 직접 해줘야 합니다.
    이는MySQL에서도 같은 사항입니다.

     

    2. code에 데이터 삭제 후 다시 데이터를 삽입했을 때 오류 설명과 같은 글이 발생한다.

    사용자가 설정한 삽입에 대한 트리거 실행 영역 INVALIDATE TRANSACTION은 트리거를 부른 이벤트 연산에 대해 수행은 하지만 커밋을 포함하고 있는 트랜잭션은 수행되지 않도록 합니다. 이는 테이터를 변경하는 이벤트가 발생한 후에 유효하지 않은 데이터를 가지는 것으로부터 보호하기 위하여 트랜잭션이 유효하지 않으면 반드시 ROLLBACK 문으로 취소시켜야 합니다.
    그러므로 오류사항으로 보신 그림처럼 트리거에 의해 에러가 출력된 것이므로, 버그가 아닙니다.
    자세한 사항은 매뉴얼을 참고하세요.(http://www.cubrid.com/online_manual/cubrid_830/syntax/syntax_trigger_create_action.htm)


    질문에 대한 원하시는 답변이 되셨기를 바랍니다.


List of Articles
번호 제목 글쓴이 날짜 조회 수
83 decimal(4,1)어케 설정하나요? & 몇가지 불편사항 3 임철수 2006.07.31 21313
82 cubsql 이라는 오픈소스 프로젝트를 시작했습니다 ㅎㅎ 8 신기배 2006.11.21 15566
81 cubrid를 잠깐 사용해 보고.. 7 신기배 2006.07.02 22950
80 cubrid 홈페이지 글씨체에 대해서 2 프란체스카 2009.03.10 17592
79 cubrid mysql 하루 체험 소감 1 차가워 2015.03.16 8635
» cubrid 3.0 버그. 1 file 코딩하는자아 2010.10.07 12369
77 [좌담회] 자발적 커뮤니티 `SW 두레활동` 확산시켜야 cubrid 2010.12.24 23135
76 [도서 소개] 이클립스 PDT file 정병주 2011.05.11 25756
75 [도서 소개] 김태용의 JSP 웹 프로그래밍 입문 file cubrid 2011.01.21 22463
74 [기사] 공개SW 유지보수 가이드라인 만들어진다. 정병주 2006.08.08 18862
73 Windows 2003 + CUBRID 2008 R 1.4 + ZBXE 1.2.0 + Autoset 4.3.2 설치 후기 2 윤희서 2009.03.20 26822
72 Visual-SQL에서 데이타베이스명까지 저장과 ... 2 채광수 2006.06.21 20188
71 Talk Box는 개발자용 자유게시판입니다. 관리자 2006.06.16 23930
70 Sphinx 라는 검색엔진을 지원했으면 합니다. 2 정순영 2009.09.18 19476
69 SPRING+IBATIS+DWR 포팅 후기 3 장비맨 2009.04.23 20525
68 SDEC (Seoul Data Engineering Camp) 2011 - 개발자 중심의 기술 컨퍼런스 file 정병주 2011.05.13 27844
67 R3.0질문입니다. 2 겜기능되거든 2010.10.07 12124
66 Query Browser 미흡한 점 1 GGG특별대원 2011.04.04 23432
65 Q&A 신속한 답변 부탁 드립니다. 1 스마트 2010.09.27 11521
64 Q&A 글이 안써지네... 4 ㅇㅇ 2013.01.28 13063
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 Next
/ 13

Contact Cubrid

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