در پروژه خودم که با Asp.net core هست یک Entity مشابه زیر رو دارم
public class Candidator
{
[Key]
public int CandidatorID { get; set; }
public string FirstName { get; set; }
public string Family { get; set; }
public int ProvienceID { get; set; }
[ForeignKey("ProvienceID")]
public virtual Provience Provience { get; set; }
}
موقعی که میخوام با استفاده از دستورات Migration این جدول رو داخل Sql Server ایجاد کنم خطا میده و عملیات انجام نمیشه
Add-Migration mig-name
update-database
خطایی که برمیگردونه خطای زیر هست
Introducing FOREIGN KEY constraint 'Fk_Candidator' on Table Candidator may cause cycles or multiple cascade paths
دوستان لطفا راهنمایی کنید غلت این خطا چی هست و چجوری میتونم این خطا رو داخل انتیتی فریم ورک حل کنم
مشکل شما Multiple cascade paths هست. به این معنی که یک اگر یک ردیف از جدول Provience حذف بشه همه ی ردیف های مرتبط با اون در جدول Candidator حذف میشه.
شما می تونید با استفاده از کد زیر این مشکل رو حل کنید :
protected override void OnModelCreating(ModelBuilder builder)
{
builder.Entity<Candidator>().HasOne(p => p.provienceID).WithMany(b => b.ProvienceID)
.OnDelete(DeleteBehavior.Restrict);
}
البته یک راه حل ساده تر هم وجود داره. میتونید کدهاتون رو به شکل زیر هم تغییر بدید
public class Candidator
{
[Key]
public int CandidatorID { get; set; }
public string FirstName { get; set; }
public string Family { get; set; }
public int? ProvienceID { get; set; }
[ForeignKey("ProvienceID")]
public virtual Provience Provience { get; set; }
}
در این صورت اگر مقدار ProvienceID در جدول اصلی حذف بشه در جدول Candidator مقدار null رو میپذیره
من انجام دادم و حل شد !
فقط چند مسئله :
چرا در هیچ آموزشی به این علامت سوال پس از int در property تاکید نشده ؟ (?int)
تاریخ :
1403/08/29
- ساعت :
07:15:00 PM
- بازدید :
76
- پاسخ :
0
|
تاریخ :
1403/08/18
- ساعت :
10:40:00 AM
- بازدید :
109
- پاسخ :
0
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
1033
- پاسخ :
1
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
429
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1356
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4798
- پاسخ :
1
|
تاریخ :
1403/07/27
- ساعت :
03:21:00 PM
- بازدید :
214
- پاسخ :
1
|
تاریخ :
1403/07/26
- ساعت :
09:00:00 PM
- بازدید :
117
- پاسخ :
0
|
تاریخ :
1403/05/16
- ساعت :
09:57:00 AM
- بازدید :
396
- پاسخ :
2
|
تاریخ :
1403/06/25
- ساعت :
11:39:00 PM
- بازدید :
567
- پاسخ :
1
|
تاریخ :
1401/02/24
- ساعت :
02:17:00 PM
- بازدید :
2011
- پاسخ :
1
|
تاریخ :
1403/08/29
- ساعت :
07:15:00 PM
- بازدید :
76
- پاسخ :
0
|
تاریخ :
1403/08/18
- ساعت :
10:40:00 AM
- بازدید :
109
- پاسخ :
0
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
1033
- پاسخ :
1
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
429
- پاسخ :
1
|
تاریخ :
1402/08/01
- ساعت :
06:25:00 PM
- بازدید :
930
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1356
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4798
- پاسخ :
1
|
تاریخ :
1402/09/08
- ساعت :
07:34:00 PM
- بازدید :
1160
- پاسخ :
1
|
تاریخ :
1402/09/21
- ساعت :
11:10:00 PM
- بازدید :
597
- پاسخ :
1
|