INSERT INTO xxx (col) SELECT ...
numaralı telefonu çalıştırırken MySQL 5.6 InnoDb ile NOT NULL adlı bir yabancı anahtarı yok sayıyorum. Ekleme, diğer biçimlerde eklerken kısıtlama zorlanır. Yabancı anahtar kontrolünü etkindir ve sql_mode = STRICT_TRANS_TABLES,STRICT_ALL_TABLES,NO_ENGINE_SUBSTITUTION
MySQL Insert Select NOT NULL Constraint'ı Zorlama Yok
İşte bir örnek:
CREATE TABLE Test_Parent
(
id BIGINT(18) UNSIGNED PRIMARY KEY NOT NULL AUTO_INCREMENT,
dummy VARCHAR(255)
) ENGINE = InnoDB DEFAULT CHARACTER SET = utf8 COLLATE = utf8_unicode_ci
COMMENT 'Test parent table';
CREATE TABLE Test_Child
(
id BIGINT(18) unsigned PRIMARY KEY NOT NULL AUTO_INCREMENT,
fid BIGINT UNSIGNED NOT NULL,
FOREIGN KEY Fk_Test_Parent_01(fid) REFERENCES Test_Parent(id)
) ENGINE = InnoDB DEFAULT CHARACTER SET = utf8 COLLATE = utf8_unicode_ci
COMMENT 'Test child table';
INSERT INTO Test_Parent(dummy)
VALUES ('test');
## Here's where the FK constraint should be enforced but isn't ##
INSERT INTO Test_Child(fid)
SELECT id
FROM Test_Parent
WHERE dummy = 'missing value';
1 row affected in 5ms
## Running an insert with a different format, the constraint is enforced ##
INSERT INTO Test_Child(fid)
VALUES (null);
Column 'fid' cannot be null
## Running this format, the foreign key is also enforced ##
INSERT INTO Test_Child(id, fid)
VALUES (123, (SELECT id FROM Test_Parent WHERE dummy = 'missing value'));
Column 'fid' cannot be null
MySQL 3 insert tabloların dışında 2 yabancı anahtar zorunlu kılar neden anlamıyorum. Herhangi bir fikir?
çünkü 'WERE' deyimi eşleşmediğinden, INSERT ... SELECT' aslında herhangi bir satır ekinde sonuçlanmaz. Eğer her iki tablodan “SELECT *” ise, “Test_Child” satırında hiçbir satır görmüyorum ... http: //sqlfiddle.com/#! 9/7413e0/1 –
Gerçek verileriniz ve kullanım durumunuz önemli ölçüde farklı değilse Test bizim için ayarladı. –
Doğru - 1 satır eklendiğini bildiriyor, ancak tabloya hiçbir şey eklenmedi. Bu senaryoda "NULL değil" kısıtının uygulanmasını beklerim. Bunun yerine, istisna yutulurmuş gibi. – adam