簡體   English   中英

MySQL約束不起作用-錯誤代碼#1452

[英]MySQL Constraint not working - error code #1452

整整一整天,我一直在努力擺脫這種束縛。

涉及的表的代碼是:

CREATE TABLE IF NOT EXISTS `GEBRUIKER` 
(
`GEBRUIKERSNR` varchar(5) NOT NULL,
`VOORNAAM` text,
`TUSSENVOEGSEL` text,
`ACHTERNAAM` text NOT NULL,
`GESLACHT` BOOLEAN,
`WACHTWOORD` text NOT NULL,
`GEB_DATUM` DATE,
`E-MAIL` text NOT NULL,
`TELEFOON` INT(10),
`STRAAT` text,
`HUISNUMMER` INT(3),
`POSTCODE` text,
`WOONPLAATS` text,      

PRIMARY KEY (`GEBRUIKERSNR`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Gegevens worden uitgevoerd voor tabel `GEBRUIKERS`
--

INSERT INTO `GEBRUIKER` (`GEBRUIKERSNR`, `VOORNAAM`, `TUSSENVOEGSEL`, `ACHTERNAAM`,     `GESLACHT`, `WACHTWOORD`, `GEB_DATUM`, `E-MAIL`, `TELEFOON`, `STRAAT`, `HUISNUMMER`, `POSTCODE`, `WOONPLAATS`) VALUES

(99999, 'An', NULL, 'Oniem', 'm', 'anoniem', 1991-12-13, 'anoniem@anoniem.net', '0612345678', 'anoniemstraat', '01', '0001 AN', 'Anoniemville');

和:

CREATE TABLE IF NOT EXISTS `AFSPRAAK`
(
`DATENUMMER` int(10) NOT NULL,
`GEBRUIKERSNR_VAN` varchar(5) NOT NULL,
`GEBRUIKERSNR_NAAR` varchar(5) NOT NULL,
`ACCEPTATIE` BOOLEAN,
`BERICHT` text,
`TIJDSTIP` DATE,
`LOCATIE` text,

PRIMARY KEY (`DATENUMMER`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Gegevens worden uitgevoerd voor tabel `AFSPRAAK`
--

INSERT INTO `AFSPRAAK` (`DATENUMMER`, `GEBRUIKERSNR_VAN`, `GEBRUIKERSNR_NAAR`, `ACCEPTATIE`, `BERICHT`, `TIJDSTIP`, `LOCATIE`) VALUES

('9999999999', '99999', '99999', TRUE, 'Hey, wanna go out? :)', '2014-02-27 11:04:00', 'Cafe de Bezige Bij, Hofstraat 5, Rotterdam');

我所做的約束的代碼是:

ALTER TABLE `AFSPRAAK`
ADD CONSTRAINT `afspraak_ibfk_2` FOREIGN KEY (`GEBRUIKERSNR_VAN`) REFERENCES `GEBRUIKER` (`GEBRUIKERSNR`) ON DELETE NO ACTION ON UPDATE NO ACTION,
ADD CONSTRAINT `afspraak_ibfk_1` FOREIGN KEY (`GEBRUIKERSNR_NAAR`) REFERENCES `GEBRUIKER` (`GEBRUIKERSNR`) ON DELETE NO ACTION ON UPDATE NO ACTION; 

從PHPMyAdmin我得到這個:

ERROR    
SQL-query:

ALTER TABLE  `AFSPRAAK` ADD CONSTRAINT  `afspraak_ibfk_2` FOREIGN KEY (  `GEBRUIKERSNR_VAN` ) REFERENCES  `GEBRUIKER` (  `GEBRUIKERSNR` ) ON DELETE NO ACTION ON UPDATE NO ACTION ,
ADD CONSTRAINT  `afspraak_ibfk_1` FOREIGN KEY (  `GEBRUIKERSNR_NAAR` ) REFERENCES  `GEBRUIKER` (  `GEBRUIKERSNR` ) ON DELETE NO ACTION ON UPDATE NO ACTION ;


MySQL reports: Documentation

#1452 - Cannot add or update a child row: a foreign key constraint fails (`dateos`.`#sql-1684_68`, CONSTRAINT `afspraak_ibfk_2` FOREIGN KEY (`GEBRUIKERSNR_VAN`) REFERENCES `gebruiker` (`GEBRUIKERSNR`) ON DELETE NO ACTION ON UPDATE NO ACTION) 

現在我該怎么做? 另外,為什么這不起作用?

您需要在外KEY列上創建INDEX

INDEX (GEBRUIKERSNR_VAN),
INDEX (GEBRUIKERSNR_NAAR)

並且您的FOREIGN KEY約束將被創建

CREATE TABLE IF NOT EXISTS `GEBRUIKER` 
(
  `GEBRUIKERSNR` varchar(5) NOT NULL,
  `VOORNAAM` text,
  `TUSSENVOEGSEL` text,
  `ACHTERNAAM` text NOT NULL,
  `GESLACHT` BOOLEAN,
  `WACHTWOORD` text NOT NULL,
  `GEB_DATUM` DATE,
  `E-MAIL` text NOT NULL,
  `TELEFOON` INT(10),
  `STRAAT` text,
  `HUISNUMMER` INT(3),
  `POSTCODE` text,
  `WOONPLAATS` text,

  PRIMARY KEY (`GEBRUIKERSNR`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

CREATE TABLE IF NOT EXISTS `AFSPRAAK`
(
  `DATENUMMER` int(10) NOT NULL,
  `GEBRUIKERSNR_VAN` varchar(5) NOT NULL,
  `GEBRUIKERSNR_NAAR` varchar(5) NOT NULL,
  `ACCEPTATIE` BOOLEAN,
  `BERICHT` text,
  `TIJDSTIP` DATE,
  `LOCATIE` text,

  PRIMARY KEY (`DATENUMMER`),
  INDEX (GEBRUIKERSNR_VAN),
  INDEX (GEBRUIKERSNR_NAAR)

) ENGINE=InnoDB DEFAULT CHARSET=latin1;

ALTER TABLE `AFSPRAAK`
  ADD CONSTRAINT `afspraak_ibfk_2` 
    FOREIGN KEY (`GEBRUIKERSNR_VAN`) 
    REFERENCES `GEBRUIKER` (`GEBRUIKERSNR`) 
        ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `afspraak_ibfk_1` 
    FOREIGN KEY (`GEBRUIKERSNR_NAAR`) 
    REFERENCES `GEBRUIKER` (`GEBRUIKERSNR`) 
      ON DELETE NO ACTION ON UPDATE NO ACTION;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM