无法添加或更新子行:即使我已经在父 table 上添加了行,外键约束也会失败

Cannot add or update a child row: a foreign key constraint fails even if I already added row on parent table

我正在尝试向子 table (transaction_tb) 添加一条记录,并且我使用了父 table 中确实存在的外键值首要的关键。但是为什么还是returns我这个上面提到的错误?

CREATE TABLE custinfo_tb(
    transactionID bigint NOT NULL,
    Col_ID int(8) NOT NULL,
    email varchar(50) NOT NULL,
    contact int(11) NOT NULL,
    address varchar(100) NOT NULL,
    tdcp varchar(100) NOT NULL,
    pc varchar(4) NOT NULL,
    PRIMARY KEY (Col_ID,transactionID)
    
  
)ENGINE=InnoDB DEFAULT CHARSET=latin1;


CREATE TABLE brokerinfo_tb
(
 transactionID bigint NOT NULL,
  Brokerid varchar(30) NOT NULL,
  Broker_contact int(15) NOT NULL,
  Account_wBroker varchar(100) NOT NULL,
  PRIMARY KEY (Brokerid,transactionID)
)ENGINE=InnoDB DEFAULT CHARSET=latin1;


CREATE TABLE stockinfo_tb
(
    transactionID bigint NOT NULL,
    Stock_Code varchar(6) NOT NULL,
    Stock_Name varchar(50) NOT NULL,
    Stock_Amount int(9) NOT NULL,
    Avecost float NOT NULL,
    Cert_amount float NOT NULL,
    PRIMARY KEY (stock_code,transactionID)
    
)ENGINE=InnoDB DEFAULT CHARSET=latin1;


CREATE TABLE transactiontype_tb
(
  transactionID bigint NOT NULL,
  Transfertype varchar(20) NOT NULL,
  transferdesc varchar(20) NOT NULL,
  transperiod varchar(10) NOT NULL,
  transfee varchar(30) NOT NULL,
  PRIMARY KEY (transfertype,transactionID)
    
)ENGINE=InnoDB DEFAULT CHARSET=latin1;


CREATE TABLE transaction_tb(
    transactionID bigint  NOT NULL AUTO_INCREMENT,
    COL_ID int NOT NULL,
    sysdate DATE,
    Stock_Code varchar(6) NOT NULL,
    Brokerid varchar(30) NOT NULL,
    Transfertype varchar(20) NOT NULL,
    PRIMARY KEY (transactionID),
    FOREIGN KEY (Col_ID,transactionID) REFERENCES custinfo_tb(Col_ID,transactionID)  ON DELETE CASCADE ON UPDATE CASCADE ,
    FOREIGN KEY (Brokerid,transactionID) REFERENCES brokerinfo_tb(Brokerid,transactionID)  ON DELETE CASCADE ON UPDATE CASCADE ,
    FOREIGN KEY (Stock_Code,transactionID) REFERENCES stockinfo_tb(Stock_Code,transactionID)  ON DELETE CASCADE ON UPDATE CASCADE ,
    FOREIGN KEY (Transfertype,transactionID) REFERENCES transactiontype_tb(Transfertype,transactionID)  ON DELETE CASCADE ON UPDATE CASCADE
    
)ENGINE=InnoDB DEFAULT CHARSET=latin1;

我输入的数据是:

INSERT INTO brokerinfo_tb (transactionID, Brokerid)
VALUES (1,1);

INSERT INTO custinfo_tb (transactionID, Col_ID)
VALUES (1,20180111);

INSERT INTO stockinfo_tb (transactionID, Stock_Code)
VALUES (1,'AR');

INSERT INTO transactiontype_tb (transactionID, Transfertype)
VALUES (1,'TRANSFER_IN');

-- THis is where it failed
INSERT INTO transaction_tb (transactionID, Brokerid, COL_ID, Stock_Code, Transfertype)
VALUES (1,1,201808111,'AR','TRANSFER_IN'); 

出了什么问题?我尝试向我的 transaction_tb table 添加一行,其中已经存在来自四个 table 的匹配行(custinfo_tb、brokerinfo_tb、stockinfo_tb 和 transactiontype_tb)

您的 custinfo_tb.Col_ID 包含 20180111。

您试图插入 transaction_tb.COL_ID 值 201808111。

比较这两个值:

20180111
201808111