mysql 错误码 外键_外键和MySQL错误

我有以下脚本在 MySQL版本5.1中创建一个表来引用其他3个表.所有3个表都是使用InnoDB创建的,并且所有3个表都将ID列定义为INT.

我已成功创建了其他表,引用了ACCOUNT和PERSON,但是,这是第一个引用ADDRESS的表,所以我在下面也包含了该表的定义,如下所示.

我得到的错误是ERROR 1005(HY000)与errno 150,我理解与外键创建有关.

失败的脚本是(为简单起见,删除了额外的列):

CREATE TABLE WORK_ORDER (

ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,

ACCOUNT_ID INT NOT NULL,

CUSTOMER_ID INT NOT NULL,

SALES_ID INT,

TRADES_ID INT,

LOCATION_ID INT NOT NULL,

INDEX CUST_INDEX(CUSTOMER_ID),

INDEX SALES_INDEX(SALES_ID),

INDEX TRADES_INDEX(TRADES_ID),

INDEX ACCOUNT_INDEX(ACCOUNT_ID),

INDEX LOCATION_INDEX(LOCATION_ID),

FOREIGN KEY (CUSTOMER_ID) REFERENCES PERSON(ID) ON DELETE CASCADE,

FOREIGN KEY (SALES_ID) REFERENCES PERSON(ID) ON DELETE SET NULL,

FOREIGN KEY (TRADES_ID) REFERENCES PERSON(ID) ON DELETE SET NULL,

FOREIGN KEY (ACCOUNT_ID) REFERENCES ACCOUNT(ID) ON DELETE CASCADE,

FOREIGN KEY (LOCATION_ID) REFERENCES ADDRESS(ID) ON DELETE SET NULL

) ENGINE=InnoDB;

用于创建ADDRESS表的SQL语句如下(为简单起见,删除了额外的列).

CREATE TABLE ADDRESS (

ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,

PERSON_ID INT NOT NULL,

ACCOUNT_ID INT NOT NULL,

ADDRESS_L1 VARCHAR(50),

ADDRESS_L2 VARCHAR(50),

CITY VARCHAR(25),

PROVINCE VARCHAR(20),

POSTAL_CODE VARCHAR(6),

COUNTRY VARCHAR(25),

INDEX CUST_INDEX(PERSON_ID),

INDEX ACCOUNT_INDEX(ACCOUNT_ID),

FOREIGN KEY (ACCOUNT_ID) REFERENCES ACCOUNT(ID) ON DELETE CASCADE,

FOREIGN KEY (PERSON_ID) REFERENCES PERSON(ID) ON DELETE CASCADE

) ENGINE=InnoDB;

我在这里浏览了几个处理类似问题的问题,但大多数似乎是重复定义和不匹配字段类型,以及一些不使用InnoDB用于其中一个或另一个表.但是,这些似乎都不是问题所在.有任何想法吗?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值