/ / मैसकल वर्कबेंच त्रुटि 1215: बाधा के लिए विदेशी कुंजी नहीं जोड़ सकता है - mysql, विदेशी-कुंजी

MySQL वर्कबेंच त्रुटि 1215: बाधा के लिए विदेशी कुंजी नहीं जोड़ सकता - mysql, विदेशी कुंजी

इसलिए Im तालिका में एक विदेशी कुंजी जोड़ने की कोशिश कर रहा है, लेकिन यह त्रुटि मिलती रही:

त्रुटि कोड: 1215. विदेशी कुंजी बाधा नहीं जोड़ सकते

कोड इस प्रकार है

create table Students

(
ID char(10) primary key not null,
StudentsName varchar(30),
Address varchar(40),
StudentsTelephone varchar(20),
constraint M1 check(len(NIM)=10),
constraint M2 check(NIM like "[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]")
)

create table Lecturers

(
CodeLecturer char(5) primary key not null,
LecturersName varchar(30),
Salary numeric,
Address varchar(40),
LecturerTelephone varchar(20),
constraint D1 check(len(CodeLecturer)=5),
constraint D2 check(CodeLecturer like "D[0-9][0-9][0-9][0-9]")

)

यह विदेशी कुंजी कोड है

create table TrHeaderKampus

(
TransactionCOde char(5) primary key not null,
ID char(10) not null,
CodeLecturer char(5) not null,
DateandTime datetime,
constraint H1 check(len(TransactioniCode)=5),
constraint H2 check(TransactionCode like "TR[0-9][0-9][0-9]"),
foreign key(ID)REFERENCES Students ON UPDATE CASCADE ON DELETE CASCADE,
foreign key(CodeLecturer)REFERENCES Lecturers ON UPDATE CASCADE ON DELETE CASCADE
)

उत्तर:

जवाब के लिए 0 № 1

MySQL प्रलेखन के रूप में विदेशी कुंजी का उपयोग करना बताते हैं: आपको न केवल तालिका प्रदान करने की आवश्यकता है, बल्कि विदेशी कुंजी का संदर्भ भी फ़ील्ड (एस) प्रदान करना होगा।

[CONSTRAINT [symbol]] FOREIGN KEY
[index_name] (index_col_name, ...)
REFERENCES tbl_name (index_col_name,...)
[ON DELETE reference_option]
[ON UPDATE reference_option]

खेतों के नाम को उन विदेशी प्रमुख बाधाओं में जोड़ें, जिनका वे संदर्भ देते हैं।