मेरे पास एक सारणी है जिसमें दो कॉलम हैं जिन्हें मैंने दो अलग-अलग तालिकाओं से कॉपी किया है। अब मैं जो करना चाहता हूं वह कॉलम नाम ईमेल और आईडी दोनों पर एक विदेशी कुंजी बाधा प्रदान करता है।विदेशी कुंजी बाधा देने के लिए तालिका बदलें
ALTER TABLE users_role_map
ADD CONSTRAINT FK_users_role_map
FOREIGN KEY (email) REFERENCES usert(email),
FOREIGN KEY (id) REFERENCES rolet(id)
ON UPDATE CASCADE
ON DELETE CASCADE;
मैं निम्नलिखित त्रुटि मिलती है:
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near 'FOREI
GN KEY (id) REFERENCES rolet(id)
ON UPDATE CASCADE
ON DELETE CASCADE' at line 4
यह सही लग रहा है। मेरे अनुभव में, मैं मैन्युअल रूप से बाधाओं या सूचकांकों का नाम भी नहीं देता हूं, मैंने माईएसक्यूएल को दृश्यों के पीछे इसे संभालने दिया है। –
हां, नामकरण वैकल्पिक है। SQL सर्वर में, जहां यह वैकल्पिक भी है, मैं नाम निर्दिष्ट करना पसंद करता हूं, हालांकि। –
बस उत्सुक, क्यों? –