|
C# การดึง Database จาก DataGridView มาลงใน TextBox แบบบ้าน ๆ |
C# การดึง Database จาก DataGridView มาลงใน TextBox แบบบ้าน ๆ
ต่อจากเรื่อง C# การใช้งาน DataSource Wizard กับ DataGridView (Access 2007)
ทำให้เราได้ DataTable มาใช้งานเป็นที่เรียบร้อยแล้ว มาบทความนี้ผมก็จะออกแบบ ฟอร์ม แบบบ้านๆ จาก DataTable บ้าน ๆ ที่ผมสร้างมาครับ ผมเริ่มจาก
ลากตารางจาก datasuorce มาลงในฟอร์ม
data:image/s3,"s3://crabby-images/5395a/5395adb35da25a6c24668248675973e496c6eaf1" alt="1 1"
เลือก คอลัมน์ ที่ต้องการนำมาใช้งาน แล้วก็ลากมาวางลงในฟอร์ม
data:image/s3,"s3://crabby-images/3078b/3078b44a46a3ed626590ad1eaa4e122517054e36" alt="2 2"
เรียบร้อยแล้วครับพร้อมส่งงานได้ 555
data:image/s3,"s3://crabby-images/629f9/629f9d951a0171509c663ef07beed8bce2a94adb" alt="3 3"
data:image/s3,"s3://crabby-images/bfe8b/bfe8b3e74b26e2e5cc089ca5a9af7bc10ed530c8" alt="4 4"
โค้ดในฟอร์มก็ประมาณนี้
Code (C#)
public partial class Form4 : Form
{
public Form4()
{
InitializeComponent();
}
private void sett_Post_ProvinceBindingNavigatorSaveItem_Click(object sender, EventArgs e)
{
this.Validate();
this.sett_Post_ProvinceBindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
}
private void Form4_Load(object sender, EventArgs e)
{
// TODO: This line of code loads data into the 'postCodeDataSet.Sett_Post_Province' table. You can move, or remove it, as needed.
this.sett_Post_ProvinceTableAdapter.Fill(this.postCodeDataSet.Sett_Post_Province);
}
}
เรามาดูการ Binding เผื่อได้ใช้ประโยชน์จากมันมั่ง
ในฟอร์ม ตรงส่วนของ pvnIDTextBox เมื่อเราลาก คอลัมน์ มาลงในฟอร์ม ก็จะมีการ Binding อย่างอัตโนมัติอยู่แล้วครับ
data:image/s3,"s3://crabby-images/01524/015249b891124eef6fc505ac59912c6086e72ffb" alt="5 5"
ส่วนของ โค้ดการ Binding ก็จะเป็นแบบนี้ครับ
Code (C#)
this.pvnIDTextBox.DataBindings.Add(new System.Windows.Forms.Binding("Text", this.sett_Post_ProvinceBindingSource, "pvnID", true));
ลากวางๆๆๆๆ เยอะ ๆ ออกแบบดีๆซักหน่อยก็ออกมาเป็นแบบนี้ครับ
data:image/s3,"s3://crabby-images/48071/48071f42706d46e10dca3905f1a29724da22b932" alt="6.1 6.1"
data:image/s3,"s3://crabby-images/a84d3/a84d3a4484f172d2009846b87078745ad5ad1b56" alt="6.2 6.2"
data:image/s3,"s3://crabby-images/d27c4/d27c4634506d9016c034ce2abaeffe4b93bf5b10" alt="6.3 6.3"
เมื่อเราลาก datasuorce มาลงในฟอร์ม หลาย ๆ table มีแค่ TableAdapter.Fill มาให้ครับ bindingNavigator จะไม่มาด้วยครับ เราก็ก๊อบมาวางเอาง่ายดีแต่ต้องอย่าลืมตั้งค่า BindingSource ให้ตรงกับที่ต้องการด้วยครับ
data:image/s3,"s3://crabby-images/0910e/0910e954614dc4f4d0fb771a51b13a02fd1f1d5c" alt="7 7"
แค่นี้เราก็ได้ bindingNavigator ที่ใช้งานได้แล้วครับ
ส่วนการบันทึกใน database ก็แค่ก๊อบจากตัวเดิมมาลงใน event ของbindingNavigator นั้น ๆครับ แล้วก็เปลี่ยนชื่อ BindingSource
Code (C#)
//Update
this.Validate();
this.ชื่อ BindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
แต่เมื่อเรา save data จำต้อง refresh ข้อมูลครับ ผมจึงต้องเพิ่มโค้ดบ้านๆ อีกตัวลงไปคือ TableAdapter.Fill โค้ดบ้านๆโดยรวมจึงออกมาแบบนี้ครับ
Code (C#)
public partial class Form4 : Form
{
public Form4()
{
InitializeComponent();
}
private void Form4_Load(object sender, EventArgs e)
{
// TODO: This line of code loads data into the 'postCodeDataSet.Sett_Post_PostCode' table. You can move, or remove it, as needed.
this.sett_Post_PostCodeTableAdapter.Fill(this.postCodeDataSet.Sett_Post_PostCode);
// TODO: This line of code loads data into the 'postCodeDataSet.Sett_Post_PostOffice' table. You can move, or remove it, as needed.
this.sett_Post_PostOfficeTableAdapter.Fill(this.postCodeDataSet.Sett_Post_PostOffice);
// TODO: This line of code loads data into the 'postCodeDataSet.Sett_Post_Amphur' table. You can move, or remove it, as needed.
this.sett_Post_AmphurTableAdapter.Fill(this.postCodeDataSet.Sett_Post_Amphur);
// TODO: This line of code loads data into the 'postCodeDataSet.DataTable1' table. You can move, or remove it, as needed.
this.dataTable1TableAdapter.Fill(this.postCodeDataSet.DataTable1);
// TODO: This line of code loads data into the 'postCodeDataSet.Sett_Post_Province' table. You can move, or remove it, as needed.
this.sett_Post_ProvinceTableAdapter.Fill(this.postCodeDataSet.Sett_Post_Province);
}
#region _SaveData
private void toolStripButton7_Click(object sender, EventArgs e)
{
//Update PostCode
this.Validate();
this.sett_Post_PostCodeBindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
this.sett_Post_PostCodeTableAdapter.Fill(this.postCodeDataSet.Sett_Post_PostCode);
}
private void toolStripButton14_Click(object sender, EventArgs e)
{
//Update PostCode
this.Validate();
this.sett_Post_ProvinceBindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
this.sett_Post_ProvinceTableAdapter.Fill(this.postCodeDataSet.Sett_Post_Province);
}
private void toolStripButton21_Click(object sender, EventArgs e)
{
//Update Amphur
this.Validate();
this.sett_Post_AmphurBindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
this.sett_Post_AmphurTableAdapter.Fill(this.postCodeDataSet.Sett_Post_Amphur);
}
private void toolStripButton28_Click(object sender, EventArgs e)
{
//Update PostOffice
this.Validate();
this.sett_Post_PostOfficeBindingSource.EndEdit();
this.tableAdapterManager.UpdateAll(this.postCodeDataSet);
this.sett_Post_PostOfficeTableAdapter.Fill(this.postCodeDataSet.Sett_Post_PostOffice);
}
#endregion
}
จาก C# การใช้ DataGridViewComboBoxColumn ใน DataGridView แบบบ้าน ๆ
ผมจะเอา รายชื่อจังหวัด อำเภอ ตู้ไปรณีษย์ มาทำเป็น DataGridViewComboBoxColumn ออกมาได้เป็นแบบนี้ครับ
data:image/s3,"s3://crabby-images/e45bb/e45bb048590dd4f991fdea64450ecd9f39243ba3" alt="8 8"
data:image/s3,"s3://crabby-images/4c349/4c349e094a736b8c5ee65efeb9e75791b680f422" alt="9 9"
ปรับ AlternatingRowsDefaultCellStyle ซะหน่อย
DataGridView แบบบ้าน ๆ ก็จะยิ่ง บ้านๆ หนักกว่าเดิม 5555
data:image/s3,"s3://crabby-images/0ab14/0ab14ff242554dd37b9429682964e7982a6661fa" alt="10 10"
C# การดึง Database มาลงใน TextBox แบบบ้าน ๆ ก็ขอจบลงเพียงเท่านี้ครับ เนื่องจากใช้ความรู้แบบบ้านๆ จึงได้โค้ด และ หลักการแบบบ้านๆ มาเขียนบทความแบบบ้านๆ ให้อ่านกันครับ
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
|
|
|
|
data:image/s3,"s3://crabby-images/5d50d/5d50d6c29239a9da7fed3c75f52401da0488417f" alt="" |
|
|
|
By : |
TOR_CHEMISTRY
|
|
Article : |
บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
Create Date : |
2015-10-06 |
|
Download : |
No files |
|
Sponsored Links |
|
|
|
|
|
|