2 ضمیمه
چگونه با entity همه اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم
با سلام
در فرم خود یک کمبوباکس دارم که اطلاعات کمبوباکس از دیتابیس خوانده و در کمبوباکس نمایش داده می شود کمبوباکس به صورت زیر است
ضمیمه 117209
در نظر دارم در کمبوباکس آیتمهای نمایش دهم که با انتخاب بعضی از آیتمها اطلاعات مربوط به تمام آیتمهای کمبوباکس در گرید ویو نمایش دهم شبیه عکس بالا اولین آیتم کمبوباکس آیتمی با نام(همه موارد) می باشد با انتخاب آیتم اول اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده می شود
در عکس زیر :جدول subject اطلاعات مربوط به کمبوباکس می باشد که در کمبوباکس نمایش داده می شود و جدول descrption که اطلاعات مربوط به هر آیتم در آن ذخیره می شود
ضمیمه 117210
چگونه می توان در کمبوباکس آیتمهای مشخص کنیم که با انتخاب آنها اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم مثل عکس اول آیتم همه موارد
نقل قول: چگونه با entity همه اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم
آیتم "همه موارد" را چجوری به کمبوباکس اضافه کردی؟
کد پر کردن کمبو رو بزار.
نقل قول: چگونه با entity همه اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم
چون یکی از رکوردهاست پس از روی آی دی میشه فهمید. کافیه selectedValue کمبوباکس رو چک کنی.
ولی اگر من بودم آیتم "همه موارد" رو توی دیتابیس ذخیره نمی کردم بلکه در زمان اجرا یک لیست می ساختم و آیتم ها رو بهش اضافه می کردم.
List<subject> data = new List<subject>();
data.Add(new subject() { id = -1, name = "همه موارد" });
data.AddRange(db.subject);
comboBox1.DataSource = data;
comboBox1.DisplayMember = "name";
comboBox1.ValueMember = "id";
نقل قول: چگونه با entity همه اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم
نقل قول:
چون یکی از رکوردهاست پس از روی آی دی میشه فهمید. کافیه selectedValue کمبوباکس رو چک کنی.
یعنی در رویداد SelectedIndexChanged مقدار selectedValue با دیتابیس مقایسه کنیم اگر -1 تمام اطلاعات نمایش دهیم
در نظر دارم این اختیار به مدیریت نرم افزار بدهم تا هر یک از آیتمهای کمبوباکس انتخاب کرد بتواند شبیه "همه موارد" بکند مدیریت نرم افزار این امکان داشته باشد که بتواندبه جای نمایش اطلاعات چهارمینآیتم کمبوباکس تمام اطلاعات آیتمها نمایش دهد یعنی اگر کاربر نرم افزار بر روی چهارمین آیتم کمبوباکس( پوشاک زنانه )انتخاب کرد تمام اطلاعات مربوط به تمام آیتمها مشاهده نمایید
نقل قول: چگونه با entity همه اطلاعات مربوط به تمام آیتمهای کمبوباکس مشاهده کنیم
منظور از -1 آیدی "همه موارد" در دیتابیس هست. مطابق آیدی تغییرش بده.
اگر آیدی انتخابی برابر آیدی "همه موارد" بود همه موارد رو نشون بده و اگر نه ، اطلاعاتی رو نشون بده که subjectId مطابق آیدی انخابی باشه:
private void comboBox1_SelectionChangeCommitted(object sender, EventArgs e)
{
int sid = (int)comboBox1.SelectedValue;
if (sid == -1)
{
dataGridView1.DataSource = db.description;
}
else
{
dataGridView1.DataSource = db.description.Where(i => i.subjectId == sid);
}
}