Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
 2008 최신버전에서

 CREATE TABLE board_good (
  bg_id integer auto_increment NOT NULL,
  bo_table varchar(40) default '' NOT NULL,
  wr_id integer default 0 NOT NULL,
  mb_id varchar(40) default '' NOT NULL,
  bg_flag varchar(510) default '' NOT NULL,
  bg_datetime timestamp default timestamp'09:00:00 AM 01/01/1970'  NOT NULL,
  PRIMARY KEY  (bg_id),
  UNIQUE (bo_table,wr_id,mb_id)
);

위와같이 테이블 작성후 첨부파일의 엑셀데이타를 삽입한 다음

insert into board_good ( bo_table, wr_id, mb_id, bg_flag, bg_datetime )
values ( 'dddiary', 7535, 'admin', 'good', '2010-02-25 16:10:54')

위와같은 삽입쿼리를 실행할시에

bo_table,wr_id,mb_id 이 세가지 값이 동시에 같은 값이 없는데도 오류(Operation would have caused one or more unique constraint violations.)가 납니다.

어떻게 해야하죠??
  • ?
    남재우 2010.02.26 06:00

    안녕하세요.
    자동증가 필드는 그 값을 자동적으로 증가시키기 위해 별도로 그 값을 관리하며, 그 값은 내부적으로 serial 개체를 만들어 관리를 합니다. 아울러 자동증가 속성을 가진 필드에 대하여 사용자가 임의의 값을 입력하는 것을 허용합니다. unique 속성이 없다면 사용자가 자동증가에 상관없이 값을 입력할 수 있도록 되어있습니다. 이때 그 값은 자동증가값이 관리되고 있는 serial 개체의 값에 반영되지 않습니다.
    즉, 사용자가 입력한 임의의 자동증가필드에 대한 값은 데이터베이스에서 관리하고 있는 자동증가값에 반영되지 않아 값이 중복될 가능성을 내포하고 있습니다.
    따라서 지금과 같이 자동증가 속성을 가지는 필드에 대하여 엑셀화일을 통하여 임의의 값을 입력하게 되면 그 값이 입력되기는 하지만, 데이터베이스에서 관리하는 자동증가값에는 반영되지 않아 insert 질의에서 입력시 자동증가 필드에 데이터베이스에서 관리하던 값이 입력되어 중복 오류가 발생하는 것입니다.
    결국 에러는 unique 와 상관없이 bg_id 가 PK 로 unique 가 보장되어야 하는데, 임의로 입력한 데이터에 1의 값이 들어가 있고 이를 알 수 없는 데이터베이스에서는 자동증가속성을 이용하여 1을 입력하려고 하니 unique 오류가 발생한 것입니다.
    이를 해결하기 위해서는 자동증가속성의 현재값을 사용자가 입력한 최대값으로 변경후 사용해야 합니다.
    select  max(bg_id) from board_good 와 같이 질의를 하여 bg_id 의 최대값을 얻은 후,(그 값이 20000이라고 가정하면)
    alter serial board_good_ai_bg_id start with 20000 와 같이 자동증가값이 저장되어 있는 serial 개체의 값을 변경합니다.
    serial 개체의 이름은 <테이블이름>_ai_<필드명> 으로 만들어 집니다.

    그리고 올려주신 화일에도 오류가 있습니다. 아래와 같이 2,3,4 번째 값이 unique 로 설정한 부분인데 값이 같습니다. 아마 가공하면서 중복된 것 같습니다.
    2 ddapply 1 hansolmin1004 good 2007-12-01 00:06:24
    3 ddapply 1 hansolmin1004 good 2007-12-01 15:43:23


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4442
1107 실행 오류 :-46 (Internal error: slot 3 on page 4231 of volume) 3 file reerror 2011.11.09 26847
1106 증분백업 복구가 잘 않되고 있습니다. 3 reerror 2011.11.08 11508
1105 리눅스서버에 설치된 cubrid삭제후 로그인할때마다 에러메시지가 나옵니다.(11/06=>관련 추가질문 올림) 4 secret 어려운큐브 2011.11.05 13
1104 1대의 서버에 버젼이 다른 cubrid를 설치하려고 합니다. 1 secret 어려운큐브 2011.11.03 14
1103 델파이 ADOStoredProcedure 컴포넌트에서 큐브리드저장함수의 리턴값을 받고싶습니다. 2 wolf 2011.11.03 21625
1102 Stored procedure execute error: 자바 저장프로시저 관련오류입니다. 8 wolf 2011.11.01 21792
1101 실시간 Insert처리 1 file 동해아빠 2011.10.29 12444
1100 큐브리드 버전 선택 문의 1 유니콘 2011.10.29 36237
1099 페이징과 전체 카운트 쿼리 가져올 수 있도록 해주세요.ㅠㅠ 1 마산이프로 2011.10.29 30074
1098 질의자동화 관련하여 문의드립니다. 4 ........ 2011.10.28 9080
1097 질의 자동화 실행 오류 4 hoops11 2011.10.26 8121
1096 on duplicate key update 에 대해서.. 7 초식곰 2011.10.26 12970
1095 java store procedure 실행시 "Java VM is not running" 오류 3 jetli_2012 2011.10.25 14087
1094 테이블 생성시 컬럼추가에 있는 컬럼종류에 대해 궁금합니다. 2 존케이 2011.10.22 8712
1093 DB에 BLOB 저장 관련입니다. 2 안녕하세요 2011.10.18 24200
1092 DB 로그인 시 생기는 오류입니다 3 SMINT 2011.10.18 9509
1091 초보적인 질문(?) 입니다.. 6 초식곰 2011.10.15 8544
1090 통신 프로토콜 질문 2 reerror 2011.10.14 8687
1089 디비생성에러 5 file giyoung.kim 2011.10.12 12163
1088 윈도우 도스 모드에서 쿼리 실행 방법 문의 1 ProMind 2011.10.12 11402
Board Pagination Prev 1 ... 140 141 142 143 144 145 146 147 148 149 ... 200 Next
/ 200

Contact Cubrid

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