간단한 sql 오류

shodhpfooqmm의 이미지

테이블 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 제약이 어긋나는 부분이 있나요?

sheep의 이미지

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

shodhpfooqmm의 이미지

제가 알기론 참조를 당하는 쪽은 PRIMARY KEY가 되어야 하고
참조를 하는쪽은 꼭 KEY가 아니어도 된다고 알고 있는데 틀린건가요?
배우기도 그렇게 배웠구요.

타입도 같고, 정수형이기 때문에 크기도 같고, DB 엔진도 InnoDB로 통일했는데
왜 안되는지 도무지 모르겠네요ㅜ

세이군의 이미지

test2 테이블의 CREATE 구문 오류인듯 합니다. 아래와 같이 입력해 보시지요.

CREATE TABLE test2 (
   a INT,
   b INT,
   PRIMARY KEY(a),
   FOREIGN KEY (b) REFERENCES test1(b)
) ENGINE=InnoDB;

shodhpfooqmm의 이미지

정말 간단한 구문인데 왜 안되는지 모르겠네요ㅠ

wariua의 이미지

외래키 사용을 위한 제약 조건들: 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`

shodhpfooqmm의 이미지

즉 ENGINE=InnoDB; 만 제거하면 본문에 있는 쿼리로 테이블 생성이 되네요.

제가 알기론 test2 테이블은 구문 오류가 아니지 않나요?
FOREIGN KEY (b) references test1 와 같이 하면 자동적으로 test1 테이블의 PRIMARY KEY를 test2 테이블의 b가 참조하는 것으로 알고 있습니다.
즉 참조 당하는 쪽은 무조건 PRIMARY KEY 여야 하고, 참조하는 쪽은 PRIMARY KEY 일 필요가 없는거죠.
의문이 가시질 않네요ㅠ 아무래도 저 찾아봐야 될 것 같습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.