亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#對Access進行增刪改查的完整示例

2020-01-24 01:01:10
字體:
來源:轉載
供稿:網友

這篇文章整理了C#對Access數據庫的查詢、添加記錄、刪除記錄和更新數據等一系列的操作示例,有需要的可以參考學習。

首先是AccessHelper.cs,網上有下載,下面附送一份;

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Data.OleDb;using System.Data;using System.Windows.Forms; namespace yxdain{  public class AccessHelper  {    private string conn_str = null;    private OleDbConnection ole_connection = null;    private OleDbCommand ole_command = null;    private OleDbDataReader ole_reader = null;    private DataTable dt = null;     /// <summary>    /// 構造函數    /// </summary>    public AccessHelper()    {      //conn_str = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source='" + Environment.CurrentDirectory + "http://yxdain.accdb'";      conn_str = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source='" + Environment.CurrentDirectory + "http://yxdain.accdb'";             InitDB();    }     private void InitDB()    {      ole_connection =new OleDbConnection(conn_str);//創建實例      ole_command =new OleDbCommand();    }     /// <summary>    /// 構造函數    /// </summary>    ///<param name="db_path">數據庫路徑    public AccessHelper(string db_path)    {      //conn_str ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source='"+ db_path + "'";      conn_str = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source='" + db_path + "'";             InitDB();    }     /// <summary>    /// 轉換數據格式    /// </summary>    ///<param name="reader">數據源    /// <returns>數據列表</returns>    private DataTable ConvertOleDbReaderToDataTable(ref OleDbDataReader reader)    {      DataTable dt_tmp =null;      DataRow dr =null;      int data_column_count = 0;      int i = 0;       data_column_count = reader.FieldCount;      dt_tmp = BuildAndInitDataTable(data_column_count);       if(dt_tmp == null)      {        return null;      }       while(reader.Read())      {        dr = dt_tmp.NewRow();         for(i = 0; i < data_column_count; ++i)        {          dr[i] = reader[i];        }         dt_tmp.Rows.Add(dr);      }       return dt_tmp;    }     /// <summary>    /// 創建并初始化數據列表    /// </summary>    ///<param name="Field_Count">列的個數    /// <returns>數據列表</returns>    private DataTable BuildAndInitDataTable(int Field_Count)    {      DataTable dt_tmp =null;      DataColumn dc =null;      int i = 0;       if(Field_Count <= 0)      {        return null;      }       dt_tmp =new DataTable();       for(i = 0; i < Field_Count; ++i)      {        dc =new DataColumn(i.ToString());        dt_tmp.Columns.Add(dc);      }       return dt_tmp;    }     /// <summary>    /// 從數據庫里面獲取數據    /// </summary>    ///<param name="strSql">查詢語句    /// <returns>數據列表</returns>    public DataTable GetDataTableFromDB(string strSql)    {      if(conn_str == null)      {        return null;      }             try      {        ole_connection.Open();//打開連接         if(ole_connection.State == ConnectionState.Closed)        {          return null;        }         ole_command.CommandText = strSql;        ole_command.Connection = ole_connection;         ole_reader = ole_command.ExecuteReader(CommandBehavior.Default);         dt = ConvertOleDbReaderToDataTable(ref ole_reader);         ole_reader.Close();        ole_reader.Dispose();      }      catch(System.Exception e)      {        //Console.WriteLine(e.ToString());        MessageBox.Show(e.Message);      }      finally      {        if(ole_connection.State != ConnectionState.Closed)        {          ole_connection.Close();        }      }             return dt;    }     /// <summary>    /// 執行sql語句    /// </summary>    ///<param name="strSql">sql語句    /// <returns>返回結果</returns>    public int ExcuteSql(string strSql)    {      int nResult = 0;       try      {        ole_connection.Open();//打開數據庫連接        if(ole_connection.State == ConnectionState.Closed)        {          return nResult;        }         ole_command.Connection = ole_connection;        ole_command.CommandText = strSql;         nResult = ole_command.ExecuteNonQuery();      }      catch(System.Exception e)      {        //Console.WriteLine(e.ToString());        MessageBox.Show(e.Message);        return nResult;      }      finally      {        if(ole_connection.State != ConnectionState.Closed)        {          ole_connection.Close();        }      }       return nResult;    }  }}

定義變量,設置列標題;

private AccessHelper achelp;......  private void Form1_Load(object sender, EventArgs e)  {     achelp = new AccessHelper();    string sql1 = "select * from ycyx";    databind1(sql1);        dataGridView1.Columns[0].Visible = false;    dataGridView1.Columns[1].HeaderCell.Value = "服務號碼";    dataGridView1.Columns[2].HeaderCell.Value = "客戶名稱";    dataGridView1.Columns[3].HeaderCell.Value = "歸屬地區";    dataGridView1.Columns[4].HeaderCell.Value = "當前品牌";    dataGridView1.Columns[5].HeaderCell.Value = "當前套餐";    dataGridView1.Columns[6].HeaderCell.Value = "當前狀態";  }

顯示數據表全部內容;

private void databind1(string sqlstr){  DataTable dt = new DataTable();  dt = achelp.GetDataTableFromDB(sqlstr);  dataGridView1.DataSource = dt;}

讀取要更新記錄到更新窗體控件;

private void button3_Click(object sender, EventArgs e){  if (dataGridView1.SelectedRows.Count < 1 || dataGridView1.SelectedRows[0].Cells[1].Value == null)  {    MessageBox.Show("沒有選中行。", "M營銷");    return;  }  //f3.Owner = this;  DataTable dt = new DataTable();  object oid = dataGridView1.SelectedRows[0].Cells[0].Value;  string sql = "select * from ycyx where ID=" + oid;  dt = achelp.GetDataTableFromDB(sql);  f3 = new Form3();  f3.id = int.Parse(oid.ToString());  //f3.id = 2;  f3.Text1 = dt.Rows[0][1].ToString();  f3.Text2 = dt.Rows[0][2].ToString();  f3.Text3 = dt.Rows[0][3].ToString();  f3.Text4 = dt.Rows[0][4].ToString();  f3.Text5 = dt.Rows[0][5].ToString();  f3.Text6 = dt.Rows[0][6].ToString();   f3.ShowDialog();   }

添加記錄;

private void button4_Click(object sender, EventArgs e){  if (textBox1.Text == "" && textBox2.Text == "" && textBox3.Text == "" && textBox4.Text == "" && textBox5.Text == "" && textBox6.Text == "")  {    MessageBox.Show("沒有要添加的內容", "M營銷添加");    return;  }  else  {    string sql = "insert into ycyx (fwhm,khmc,gsdq,dqpp,dqtc,dqzt) values ('" + textBox1.Text + "','" + textBox2.Text + "','"+      textBox3.Text + "','"+ textBox4.Text + "','"+ textBox5.Text + "','"+ textBox6.Text + "')";    int ret = achelp.ExcuteSql(sql);    string sql1 = "select * from ycyx";    databind1(sql1);    textBox1.Text = "";    textBox2.Text = "";    textBox3.Text = "";    textBox4.Text = "";    textBox5.Text = "";    textBox6.Text = "";  }}

刪除記錄;

private void button2_Click(object sender, EventArgs e){  if (dataGridView1.SelectedRows.Count < 1 || dataGridView1.SelectedRows[0].Cells[1].Value == null)  {    MessageBox.Show("沒有選中行。", "M營銷");  }  else  {    object oid = dataGridView1.SelectedRows[0].Cells[0].Value;    if (DialogResult.No == MessageBox.Show("將刪除第 " + (dataGridView1.CurrentCell.RowIndex + 1).ToString() + " 行,確定?", "M營銷", MessageBoxButtons.YesNo))    {      return;    }    else    {      string sql = "delete from ycyx where ID=" + oid;      int ret = achelp.ExcuteSql(sql);    }    string sql1 = "select * from ycyx";    databind1(sql1);  }}

查詢;

private void button13_Click(object sender, EventArgs e){  if (textBox23.Text == "")  {    MessageBox.Show("請輸入要查詢的當前品牌", "M營銷");    return;  }  else  {    string sql = "select * from ycyx where dqpp='" + textBox23.Text + "'";    DataTable dt = new System.Data.DataTable();    dt = achelp.GetDataTableFromDB(sql);    dataGridView1.DataSource = dt;  }}

用戶確定顯示或不顯示哪些數據列;

private void button15_Click(object sender, EventArgs e){  if (checkBox1.Checked == true)  {    dataGridView1.Columns[1].Visible = true;  }  else  {    dataGridView1.Columns[1].Visible = false;  }   if (checkBox2.Checked == true)  {    dataGridView1.Columns[2].Visible = true;  }  else  {    dataGridView1.Columns[2].Visible = false;  }   if (checkBox3.Checked == true)  {    dataGridView1.Columns[3].Visible = true;  }  else  {    dataGridView1.Columns[3].Visible = false;  }   if (checkBox4.Checked == true)  {    dataGridView1.Columns[4].Visible = true;  }  else  {    dataGridView1.Columns[4].Visible = false;  }   if (checkBox5.Checked == true)  {    dataGridView1.Columns[5].Visible = true;  }  else  {    dataGridView1.Columns[5].Visible = false;  }   if (checkBox6.Checked == true)  {    dataGridView1.Columns[6].Visible = true;  }  else  {    dataGridView1.Columns[6].Visible = false;  }}

更新數據;

  public partial class Form3 : Form  {    private AccessHelper achelp;    private int iid;     public Form3()    {      InitializeComponent();      achelp = new AccessHelper();      iid = 0;    }     // 更新    private void button1_Click(object sender, EventArgs e)    {      try      {        //UPDATE Person SET Address = 'Zhongshan 23', City = 'Nanjing'WHERE LastName = 'Wilson'        string sql = "update ycyx set fwhm='"+textBox1.Text+"',khmc='"+textBox2.Text+"',gsdq='"+textBox3.Text+"',dqpp='"+textBox4.Text+          "',dqtc='"+textBox5.Text+"',dqzt='"+textBox6.Text+"' where ID="+iid;                    int ret = achelp.ExcuteSql(sql);        if (ret > -1)        {          this.Hide();          MessageBox.Show("更新成功", "M營銷");        }      }      catch (Exception ex)      {        MessageBox.Show(ex.Message);      }             }     private void Form3_Load(object sender, EventArgs e)    {     }     public int id    {      get { return this.iid; }      set { this.iid = value; }    }      public string Text1    {      get { return this.textBox1.Text; }      set { this.textBox1.Text = value; }    }     public string Text2    {      get { return this.textBox2.Text; }      set { this.textBox2.Text = value; }    }     public string Text3    {      get { return this.textBox3.Text; }      set { this.textBox3.Text = value; }    }     public string Text4    {      get { return this.textBox4.Text; }      set { this.textBox4.Text = value; }    }     public string Text5    {      get { return this.textBox5.Text; }      set { this.textBox5.Text = value; }    }     public string Text6    {      get { return this.textBox6.Text; }      set { this.textBox6.Text = value; }    }     //取消    private void button2_Click(object sender, EventArgs e)    {      this.Hide();    }  }}

注意此處有一個技巧;C# Winform,在窗體之間傳值,或在一個窗體中設置另一個窗體的控件的值時,有多種方式;最好方式是如上代碼所示;使用.net的get、set屬性; 

控件是一個窗體的私有變量,不能在另一個窗體中直接訪問;為了在a窗體中設置b窗體的控件的值,對b窗體的控件都添加一個帶get、set的公共屬性,就可在a中設置b中控件的值,具體看代碼;

以上就是C#對Access進行增刪改查的完整示例代碼,希望對大家學習C#能有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
深夜成人在线观看| 成人欧美一区二区三区黑人| 欧美日韩999| 欧美视频二区36p| 成人美女免费网站视频| 国产精品尤物福利片在线观看| 欧美人成在线视频| 亚洲第一精品福利| 久久天天躁狠狠躁夜夜躁2014| 欧美在线一区二区三区四| 伊人伊成久久人综合网站| 国产视频丨精品|在线观看| 亚洲欧美中文日韩v在线观看| 国产精品久久久久久久久免费| 日日骚久久av| 亚洲天堂久久av| 国产精品欧美日韩| 亚洲尤物视频网| 亚洲欧洲在线观看| 亚洲国产精久久久久久久| 欧美性资源免费| 久久久久久亚洲精品中文字幕| 国产亚洲aⅴaaaaaa毛片| 成人午夜激情网| 91av中文字幕| 国产精品久久久久福利| 一本一本久久a久久精品牛牛影视| 97国产成人精品视频| 91av在线不卡| 国产精品一区二区电影| 亚洲成人激情小说| 色偷偷888欧美精品久久久| 色综合视频一区中文字幕| 91色琪琪电影亚洲精品久久| 亚洲精品成人久久电影| 中文字幕欧美日韩精品| 有码中文亚洲精品| 欧美日韩亚洲激情| 在线观看视频99| 91精品在线国产| 久久久久久久999精品视频| 国产一区二区三区日韩欧美| 性欧美办公室18xxxxhd| 91久久精品视频| 精品国产一区二区三区久久久| 国产精品久久久久一区二区| 91香蕉嫩草影院入口| 久久久精品久久久| 欧美一区二区三区四区在线| 91精品在线播放| 欧美极品少妇xxxxⅹ免费视频| 欧美富婆性猛交| 国产精品吴梦梦| 欧美日韩国产综合新一区| 黑人巨大精品欧美一区二区一视频| 日韩黄色av网站| 一区二区三区日韩在线| 国产日韩欧美在线观看| 国内精品在线一区| 国产精品激情av在线播放| 亚洲性线免费观看视频成熟| 久久久久久久影视| 久久精品国亚洲| 狠狠爱在线视频一区| 欧美三级欧美成人高清www| 欧美激情视频一区| 久久久久久国产精品美女| 亚洲小视频在线观看| 欧美激情喷水视频| 隔壁老王国产在线精品| 日韩欧美在线第一页| 欧美黑人xxx| 亚洲另类欧美自拍| 久久免费在线观看| 永久免费毛片在线播放不卡| 亚洲人成电影在线播放| 欧美丝袜美女中出在线| 一区二区av在线| 亚洲一区二区三区在线免费观看| 精品自拍视频在线观看| 中日韩美女免费视频网址在线观看| 国产精品久久久av久久久| 日韩欧美国产激情| 国产欧美一区二区三区久久人妖| 亚洲在线视频观看| 久热在线中文字幕色999舞| 亚洲精品一区二区三区婷婷月| 日韩av影视在线| 成人福利视频网| 日日狠狠久久偷偷四色综合免费| 国产精品精品久久久久久| 亚洲国产精品999| 国产亚洲精品va在线观看| 日韩av片电影专区| 精品无人区乱码1区2区3区在线| 欧美激情a在线| 国产精品99久久久久久白浆小说| 日韩av毛片网| 日韩一区二区精品视频| 亚洲一区亚洲二区| 91亚洲精品久久久久久久久久久久| 夜夜狂射影院欧美极品| 91在线观看免费网站| 中文字幕亚洲欧美一区二区三区| 欧美另类高清videos| 久久91精品国产91久久久| 国产九九精品视频| 日本精品久久久| 日韩av电影在线网| 久久精品国产电影| 国产精品视频久久| 一区二区三区www| 亚洲在线视频观看| 国产精品亚洲视频在线观看| 九色91av视频| 成人网欧美在线视频| 国产ts人妖一区二区三区| 一本色道久久88亚洲综合88| 一本色道久久综合狠狠躁篇怎么玩| 日韩在线视频中文字幕| 日韩在线免费视频观看| 国产福利视频一区二区| 亚洲色图色老头| 一区二区在线视频| www.久久久久久.com| 国产成人在线亚洲欧美| 欧美激情视频在线免费观看 欧美视频免费一| 成人性生交xxxxx网站| 91中文字幕在线| 国内精品久久久久久久| 亚洲激情视频在线观看| 91av在线国产| 色哟哟亚洲精品一区二区| 法国裸体一区二区| 中文字幕日韩欧美| 亚洲人成网站在线播| 久久69精品久久久久久久电影好| 国产精品吊钟奶在线| 欧美性猛交xxxx乱大交| 国产精品99久久久久久白浆小说| 97国产精品视频人人做人人爱| 国产精品第10页| 亚洲欧洲国产精品| 精品视频久久久久久久| 久久久国产在线视频| 久久久免费高清电视剧观看| 欧美精品国产精品日韩精品| 欧美精品免费在线观看| 欧美一区视频在线| 欧美午夜女人视频在线| 国产精品自产拍在线观看| 91精品国产自产91精品| 国产视频福利一区| 亚洲视频专区在线| 欧美孕妇性xx| 精品免费在线观看| 亚洲综合精品一区二区| 午夜精品久久久久久久99热浪潮| 久久亚洲成人精品| 欧美xxxx14xxxxx性爽| 久久在精品线影院精品国产| 日本一区二区三区四区视频| 91精品国产综合久久香蕉922| 国产美女精品视频免费观看|