映射(连接)创建 table 不允许使用外键?

Mapping (join) create table not allowing foreign keys?

我正在构建的网站有这两个 table(登录并点击)。我想让用户保存他最喜欢的舔,所以这意味着我需要一个映射 table 但它不起作用。它在没有外键约束的情况下工作,但我 want/need 外键约束。我做了研究,每个人都说要像我一样创建映射 table,但它不起作用。 谁能告诉我为什么这行不通?谢谢。

Table: 登录

CREATE TABLE `login` (
  `login_id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) DEFAULT NULL,
  `password` varchar(50) DEFAULT NULL,
  `email` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`login_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1

Table:舔

CREATE TABLE `licks` (
  `lick_id` int(11) NOT NULL AUTO_INCREMENT,
  `lick_name` varchar(50) DEFAULT NULL,
  `lick_category` varchar(20) DEFAULT NULL,
  `lick_html_pg` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`lick_id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=latin1

Table login_licks(睡不着!)

CREATE TABLE login_lick (
  login_id INT NOT NULL,
  lick_id INT NOT NULL,
  PRIMARY KEY (login_id, lick_id),
  FOREIGN KEY login_id REFERENCES login (login_id),
  FOREIGN KEY lick_id REFERENCES licks (lick_id)
);

您在外键定义中缺少括号:

CREATE TABLE login_lick (
  login_id INT NOT NULL,
  lick_id INT NOT NULL,
  PRIMARY KEY (login_id, lick_id),
  FOREIGN KEY (login_id) REFERENCES login (login_id),
  FOREIGN KEY (lick_id) REFERENCES licks (lick_id)
);

Here 是 SQL Fiddle.