سلام
من برای ساخت چند جدول در دات نت 6 از طریق کنسول اقدام کردم و بعد از ساخته شدن مایگریشن وقتی دستور Update-Database رو زدم با خطای زیر مواجهه شدم.
این عکس خطا هستش و کد تعریف جداول مربوطه در زیر می باشد.
public class CenterUsers
{
[Key]
public int CenterUsersId { get; set; }
public string CenterAdminId { get; set; }
//Strudent Or Teacher ID
public string CenterUserId { get; set; }
public int CenterId { get; set; }
//2 = Teacher
//3 = Student
public byte UserType { get; set; }
[ForeignKey("CenterAdminId")]
public virtual ApplicationUsers Users_Admin { get; set; }
[ForeignKey("CenterUserId")]
public virtual ApplicationUsers Users_ST { get; set; }
[ForeignKey("CenterId")]
public virtual Centers Centers { get; set; }
}
public class TeacherCourse
{
[Key]
public int TeacherCourseId { get; set; }
public string TeacherId { get; set; }
public int CourseId { get; set; }
public string TeacherAdminId { get; set; }
public int CenterId { get; set; }
[ForeignKey("TeacherAdminId")]
public virtual ApplicationUsers Users_Admin { get; set; }
[ForeignKey("TeacherId")]
public virtual ApplicationUsers Users_Teacher { get; set; }
[ForeignKey("CenterId")]
public virtual Centers Centers { get; set; }
[ForeignKey("CourseId")]
public virtual Courses Courses { get; set; }
}
public class Courses
{
[Key]
public int CourseId { get; set; }
public string CourseName { get; set; }
public string UserId { get; set; }
[ForeignKey("UserId")]
public virtual ApplicationUsers Users { get; set; }
}
public class Centers
{
[Key]
public int CenterId { get; set; }
public string CenterName { get; set; }
//1 = مدرسه
//2 = دانشگاه
//3 = موسسه آموزشی
//4 = سازمان یا شرکت
public byte CenterType { get; set; }
//Center Admin
public string CenterAdminId { get; set; }
[ForeignKey("CenterAdminId")]
public virtual ApplicationUsers Users { get; set; }
}
ممنون میشم راهنمایی بفرمایید.
من با دو ورژن از sql تست کردم بازم همین خطا رو میده، نمیدونم مشکل از کجاست.
شما برای ساخت این جداول بهتره که به ترتیب جداولتون رو ایجاد کنید و مایگریشن ایجاد کنید و از دستور Update-Database استفاده کنید. دلیل این امر این هست که در برخی از جداول شما از کلیدهای خارجی استفاده شده و این در حالی هست که جداول مربوطه هنوز ایجاد نشدن و عملا این یک تناقض هست.
یعنی کلیدهای خارجی دارید که هنوز رفرنس اونها در جداول مربوطه وجود نداره
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
370
- پاسخ :
1
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
909
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1281
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4746
- پاسخ :
1
|
تاریخ :
1403/07/27
- ساعت :
03:21:00 PM
- بازدید :
126
- پاسخ :
1
|
تاریخ :
1403/07/26
- ساعت :
09:00:00 PM
- بازدید :
72
- پاسخ :
0
|
تاریخ :
1403/05/16
- ساعت :
09:57:00 AM
- بازدید :
363
- پاسخ :
2
|
تاریخ :
1403/06/25
- ساعت :
11:39:00 PM
- بازدید :
469
- پاسخ :
1
|
تاریخ :
1403/06/17
- ساعت :
04:22:00 PM
- بازدید :
401
- پاسخ :
1
|
تاریخ :
1403/06/14
- ساعت :
06:44:00 PM
- بازدید :
498
- پاسخ :
0
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
370
- پاسخ :
1
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
909
- پاسخ :
1
|
تاریخ :
1402/08/01
- ساعت :
06:25:00 PM
- بازدید :
891
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1281
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4746
- پاسخ :
1
|
تاریخ :
1402/09/08
- ساعت :
07:34:00 PM
- بازدید :
1113
- پاسخ :
1
|
تاریخ :
1402/09/21
- ساعت :
11:10:00 PM
- بازدید :
564
- پاسخ :
1
|
تاریخ :
1403/07/27
- ساعت :
03:21:00 PM
- بازدید :
126
- پاسخ :
1
|
تاریخ :
1403/07/26
- ساعت :
09:00:00 PM
- بازدید :
72
- پاسخ :
0
|
تاریخ :
1403/07/13
- ساعت :
12:06:00 PM
- بازدید :
300
- پاسخ :
1
|