سلام.
یک برنامه دارم که در آن عملیات Crud انجام میشه . کلیه عملیات ها به درستی انجام میشود و عملیات افزودن و ویرایش در یک فرم دیگر انجام شده و نتیجه در جدول نمایش داده میشود.
بعد از انجام عملیات Create اطلاعات به درستی در جدول به روز می شود اما در Update عملیات به درستی انجام میشود اما با آنکه بعد از این عملیات جدول مجدد به روز رسانی میشود اما اطلاعات ویرایش شده در جدول به روز رسانی نمی شود. اما برنامه را بسته و مجدد باز کنید اطلاعات ویرایش شده به درستی نمایش داده می شود.
برنامه با EF Core 3.1 و Code First طراحی شده است.
ببینید شما وقتی در فرم روی دکمه ویرایش کلیک می کنید Id کاربر رو دریافت می کنید و به فرم ویرایش منتقل می کنید. کد زیر :
private void btnEdit_Click(object sender, EventArgs e)
{
variable.id = int.Parse(dataGridView1.CurrentRow.Cells[0].Value.ToString());
OpenForm();
LoadDataGrid();
}
خب در متد OpenForm هم که فرم ویرایش رو صدا می زنید و نمایشش میدید
private void OpenForm()
{
frmNewEditeStudent frm = new frmNewEditeStudent();
frm.ShowDialog();
}
بعد از اینکه فرم ویرایش باز شد و اطلاعات رو ویرایش کردید و دکمه ویرایش رو زدید عملیات ویرایش اطلاعات انجام میشه.
private void btnEditSave_Click(object sender, EventArgs e)
{
var model = db.tblStudent.Where(x => x.stdId == id).FirstOrDefault();
model.StudentName = txtStudentName.Text;
db.tblStudent.Update(model);
db.SaveChanges();
variable.id = 0;
this.Close();
}
خب دقت کنید اطلاعات در اینجا در دیتابیس ویرایش میشه اما وقتی دستور this.close اجرا میشه و فرم ویرایش بسته میشه و به فرم اول برمیگردید دستور LoadDataGrid صدا زده میشه و در اینجا هم کد زیر رو دارید:
public void LoadDataGrid()
{
var list = db.tblStudent.ToList();
dataGridView1.DataSource = list;
}
نکته : خب نکته در همینجاست، درسته که شما مجدد کوئری رو اجرا می کنید. اما این کوئری از db داره اجرا میشه و db در این لحظه آپدیت های رکوردهای دیتابیس رو درون خودش نداره و چیزی از آپدیت رو نمی تونید ببینید.
اما راه حل : کدهای بالا که همه کدهای خودتون بود. راه حل فقط یک خط کد هست و در ادامه میگم بهتون
public void LoadDataGrid()
{
//در اینجا باید یک بار دیگر دیتابیس را نمونه سازی کنید.
db = new SchoolContext();
var list = db.tblStudent.ToList();
dataGridView1.DataSource = list;
}
باید دیتابیس رو مجدد نمونه سازی کرد تا همه تغییرات شامل آپدیت ها و اضافه و حذف ها رو شامل بشه.
تاریخ :
1400/12/18
- ساعت :
10:24:00 AM
- بازدید :
2035
- پاسخ :
1
|
تاریخ :
1401/01/26
- ساعت :
12:14:00 PM
- بازدید :
2894
- پاسخ :
1
|
تاریخ :
1403/10/20
- ساعت :
11:39:00 AM
- بازدید :
85
- پاسخ :
1
|
تاریخ :
1399/06/07
- ساعت :
12:45:00 PM
- بازدید :
8160
- پاسخ :
1
|
تاریخ :
1398/08/02
- ساعت :
02:59:00 AM
- بازدید :
5765
- پاسخ :
4
|
تاریخ :
1403/10/18
- ساعت :
10:20:00 PM
- بازدید :
96
- پاسخ :
1
|
تاریخ :
1402/10/30
- ساعت :
05:11:00 PM
- بازدید :
790
- پاسخ :
1
|
تاریخ :
1403/10/13
- ساعت :
09:45:00 PM
- بازدید :
123
- پاسخ :
1
|
تاریخ :
1403/10/13
- ساعت :
09:13:00 PM
- بازدید :
81
- پاسخ :
1
|
تاریخ :
1403/10/13
- ساعت :
08:31:00 PM
- بازدید :
92
- پاسخ :
1
|
تاریخ :
1403/11/03
- ساعت :
07:34:00 PM
- بازدید :
51
- پاسخ :
0
|
تاریخ :
1399/12/20
- ساعت :
10:32:00 AM
- بازدید :
2517
- پاسخ :
1
|
تاریخ :
1398/08/09
- ساعت :
07:44:00 PM
- بازدید :
4855
- پاسخ :
1
|
تاریخ :
1399/09/20
- ساعت :
01:30:00 PM
- بازدید :
2570
- پاسخ :
1
|
تاریخ :
1403/11/03
- ساعت :
07:21:00 PM
- بازدید :
39
- پاسخ :
0
|
تاریخ :
1403/10/22
- ساعت :
12:29:00 PM
- بازدید :
81
- پاسخ :
1
|
تاریخ :
1399/09/20
- ساعت :
01:21:00 PM
- بازدید :
6640
- پاسخ :
1
|
تاریخ :
1403/11/02
- ساعت :
08:17:00 PM
- بازدید :
44
- پاسخ :
0
|
تاریخ :
1398/10/15
- ساعت :
08:02:00 PM
- بازدید :
2726
- پاسخ :
1
|
تاریخ :
1398/10/19
- ساعت :
02:01:00 PM
- بازدید :
3087
- پاسخ :
2
|