C#winform dataGridView更新資料庫

來源:互聯網
上載者:User

 

 dataGridView更新資料庫可以分2中情況:

 

1 dataGridView更新資料庫自訂資料來源更新資料庫,

2  dataGridView資料來源控制項更新資料庫。

當dataGridView控制項啟用了編輯、刪除功能,你編輯了dataGridView中到列該dataGridView對應到dataset中到資料也會跟著更新但要把資料更新到資料庫還需要一些代碼到支援。

我們先說第一種情況:dataGridView更新資料庫自訂資料來源更新資料庫

1)當資料庫表有主鍵時,我們可通過全域變數dataset或者datatable,利用DataAdapter.Update()更新到資料庫。

  1. public partial class Form1 : Form  
  2.     {  
  3.         private DataTable DT = new DataTable();  
  4.        private SqlDataAdapter SDA = new SqlDataAdapter();  
  5.   
  6.         public Form1()  
  7.         {  
  8.              InitializeComponent();  
  9.          }  
  10.   
  11.         private void Form1_Load(object sender, EventArgs e)  
  12.         {  
  13.   
  14.              SqlConnection conn = new SqlConnection("server=127.0.0.1;database=pubs;uid=sa");  
  15.              SqlCommand SCD = new SqlCommand("select * from tables", conn);  
  16.              SDA.SelectCommand = SCD;  
  17.              SDA.Fill(DT);  
  18.              dataGridView1.DataSource = DT;  
  19.          }  
  20.  
  21.  
  22. #region   使用Update更新資料庫  
  23.         private void button_save_Click(object sender, EventArgs e)  
  24.         {  
  25.             try  
  26.             {  
  27.                  SqlCommandBuilder SCB = new SqlCommandBuilder(SDA);                  
  28.                  SDA.Update(DT);  
  29.              }  
  30.             catch (System.Exception ex)  
  31.             {  
  32.                  MessageBox.Show(ex.ToString());  
  33.                 return;  
  34.              }  
  35.              MessageBox.Show("更新成功!");  
  36.          }  
  37. #endregion  

 

2)當資料庫表沒有主鍵時,要通過讀取dataGridView改變到資料行通過SQL語句更新資料庫(這個沒用試暫時沒有代碼)。其實每個表都應該有主鍵到,哪怕說自增的。

2  dataGridView資料來源控制項更新資料庫。

當dataGridView到資料來源是資料來源控制項控制項時,更新變到簡單多了(也需要有主鍵)。我們看到頁面底部裡有一個TableAdapter(注意這裡不是DataAdapter),該TableAdapter已經綁定CommandBuilder只須調用TableAdapter.update(ds.表名)就可以搞定。dataset也說有到,所以這個相對簡單到多。  

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.