간단한 sql 오류
글쓴이: shodhpfooqmm / 작성시간: 금, 2012/02/10 - 8:50오후
테이블 test1는
CREATE TABLE test1 (a INT, b INT, PRIMARY KEY (a))ENGINE=InnoDB;
테이블 test2는
CREATE TABLE test2 (a INT, b INT, PRIMARY KEY(a), FOREIGN KEY(b) REFERENCES test1)ENGINE=InnoDB;
분명히 맞다고 보는데 왜 150번 에러가 뜨면서 안될까요?
foreign key 제약이 어긋나는 부분이 있나요?
Forums:
SQL 공부한지는 꽤 되지만... 테이블
SQL 공부한지는 꽤 되지만...
테이블 test1에서 key는 a가 primary key인건 확실한데...
b는 primary key가 아닌 그냥 field입니다...
primary key가 아닌 field가 다른 테이블에서 foreign key로 선언 되니까 발생하는 에러 같은데요?
field 이름이 중복되는것도 좋은것 같진 않습니다...
PS.
error 150이 뭔지 구글링 해 봤습니다...
질문을 하실 때 무슨 에러인지 자세히 적어 놓으시면 답변을 다는데 도움이 됩니다...
--------
From Buenos Aires, Argentina
No sere feliz pero tengo computadora.... jaja
닥치고 Ubuntu!!!!!
To Serve My Lord Jesus
blog: http://sehoonpark.com.ar
http://me2day.net/sheep
이 경우는 예시를 보여주기 위해 간단히 변수명을 정한 것인데요.
제가 알기론 참조를 당하는 쪽은 PRIMARY KEY가 되어야 하고
참조를 하는쪽은 꼭 KEY가 아니어도 된다고 알고 있는데 틀린건가요?
배우기도 그렇게 배웠구요.
타입도 같고, 정수형이기 때문에 크기도 같고, DB 엔진도 InnoDB로 통일했는데
왜 안되는지 도무지 모르겠네요ㅜ
test2 테이블의 CREATE 구문 오류인듯
test2 테이블의 CREATE 구문 오류인듯 합니다. 아래와 같이 입력해 보시지요.
똑같이 안되네요ㅠ
정말 간단한 구문인데 왜 안되는지 모르겠네요ㅠ
외래키 사용을 위한 제약 조건들:
외래키 사용을 위한 제약 조건들: http://dev.mysql.com/doc/refman/5.5/en/innodb-foreign-key-constraints.html
지금 문제가 되는 조건은 "InnoDB requires indexes on foreign keys and referenced keys"입니다.
즉, test1 테이블의 b 필드로 인덱스 만들어 주시면 됩니다. 그리고 세이군님 답글처럼 구문도 정확하게 고쳐주셔야 하구요.
$PWD `date`
본문에서 InnoDB만 빼면 테이블이 생성되네요ㅠ
즉 ENGINE=InnoDB; 만 제거하면 본문에 있는 쿼리로 테이블 생성이 되네요.
제가 알기론 test2 테이블은 구문 오류가 아니지 않나요?
FOREIGN KEY (b) references test1 와 같이 하면 자동적으로 test1 테이블의 PRIMARY KEY를 test2 테이블의 b가 참조하는 것으로 알고 있습니다.
즉 참조 당하는 쪽은 무조건 PRIMARY KEY 여야 하고, 참조하는 쪽은 PRIMARY KEY 일 필요가 없는거죠.
의문이 가시질 않네요ㅠ 아무래도 저 찾아봐야 될 것 같습니다.
댓글 달기