मुझे कोई समस्या नहीं है MySQL 5.6 InnoDb INSERT INTO xxx (col) SELECT ...
चलाते समय एक गैर-विदेशी विदेशी कुंजी को अनदेखा कर रहा है। अन्य प्रारूपों में सम्मिलन बयान चलाते समय बाधा ठीक से लागू होती है। विदेशी कुंजी चेकों सक्षम हैं, और sql_mode = STRICT_TRANS_TABLES,STRICT_ALL_TABLES,NO_ENGINE_SUBSTITUTION
MySQL सम्मिलित करें चयन न करें पूर्ण अवरोध
यहाँ एक उदाहरण है:
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 डालने बयानों में से 2 के लिए विदेशी कुंजी को लागू करेगा। कोई विचार?
मुझे आश्चर्य है कि अगर आप एक गलत "1 पंक्ति प्रभावित" देख रहे हैं क्योंकि कि 'INSERT ... SELECT' वास्तव में किसी भी पंक्ति सम्मिलित नहीं होता है क्योंकि 'WHERE' क्लॉज मेल नहीं खाता है। यदि मैं दोनों टेबलों से 'चयन * करता हूं, तो मुझे 'Test_Child' में कोई पंक्ति नहीं दिखाई देती है ... http: //sqlfiddle.com/#! 9/7413e0/1 –
यह तब तक है जब तक कि आपका वास्तविक डेटा और उपयोग केस महत्वपूर्ण रूप से भिन्न न हो टेस्ट सेट जो आपने हमारे लिए सेट किया है। –
यह सही है - यह 1 पंक्ति को डालने के रूप में रिपोर्ट करता है, लेकिन वास्तव में तालिका में कुछ भी डाला नहीं गया है। मैं उम्मीद करता हूं कि इस परिदृश्य में 'न्यूल' की बाधा लागू नहीं होगी। इसके बजाए, ऐसा लगता है कि अपवाद निगल गया है। – adam