为什么仍然可以插入不存在的外键?

时间:2010-02-23 20:01:03

标签: mysql foreign-keys

mysql>  create table products(id integer unsigned auto_increment primary key);
Query OK, 0 rows affected (0.05 sec)

mysql> CREATE TABLE orders (
    ->     id integer PRIMARY KEY auto_increment,
    ->     product_id integer REFERENCES products (id),
    ->     quantity integer,
    ->     INDEX product_id_idx (product_id)
    -> );
Query OK, 0 rows affected (0.05 sec)
mysql> insert into orders(product_id,quantity) value(1,1);
Query OK, 1 row affected (0.00 sec)

由于产品1不存在,insert语句应该失败,但实际上不是。

为什么?

2 个答案:

答案 0 :(得分:4)

您应该在列定义下面明确定义外键。

您还应该使product_id无符号,因为父键是无符号的:

CREATE TABLE orders (
  id integer PRIMARY KEY auto_increment,
  product_id integer unsigned,
  quantity integer,
  INDEX product_id_idx (product_id),
  CONSTRAINT FK_ORDER_TO_PRODUCT FOREIGN KEY (product_id) REFERENCES products (id)
 ) engine=innodb;

答案 1 :(得分:1)

仅当MySQL使用InnoDB存储引擎时才支持外键。

MySQL使用MyISAM作为默认存储引擎,其中外键约束被简单地忽略。

请尝试使用以下表格的示例:

CREATE TABLE products (
     id integer unsigned auto_increment primary key
) ENGINE=INNODB;

CREATE TABLE orders (
     id integer PRIMARY KEY auto_increment,
     product_id integer unsigned,
     quantity integer,
     INDEX product_id_idx (product_id),
     FOREIGN KEY (product_id) REFERENCES products (id)
) ENGINE=INNODB;

还要确保引用列和引用列具有完全相同的数据类型。