【總結】C# Access 數據庫 增刪查改 的簡單步驟


 
 
引用集:
using System.Data.OleDb;

static string exePath = System.Environment.CurrentDirectory;//本程序所在路徑
 
//創建連接對象
OleDbConnection conn = new OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0;data source=" + exePath + @"\文件名.mdb"); 

1.和查詢有關的 如獲取表數據(包括所謂的“刷新”和“連接數據庫”)、按條件查詢, 都是用的 OleDbDataAdapter
 
private void 獲取數據表/查詢()
{
    conn.Open();

    //獲取數據表
    //string sql = "select * from 表名 order by 字段1";
    //查詢
    string sql = "select * from 表名 where 字段2="...;
 
    OleDbDataAdapter da = new OleDbDataAdapter(sql, conn); //創建適配對象
    DataTable dt = new DataTable(); //新建表對象
    da.Fill(dt); //用適配對象填充表對象
    dataGridView1.DataSource = dt; //將表對象作為DataGridView的數據源
 
    conn.Close();
}

其中“獲取數據表”屬於頻繁被嵌套調用的方法,所以應去掉頭尾的conn.Open和Close,以免和其他方法中的Open發生累加從而報錯。



2.凡涉及修改表數據的 ,如增、刪、保存修改, 都是用 OleDbCommand

private void 增/刪/改()
{
     conn.Open();

     //
     string sql = "insert into 表名(字段1,字段2,字段3,字段4)values(...)";
     ////string sql = "delete from 表名 where 字段1="...; 
     ////string sql = "update student set 學號=" ...; 
 
     OleDbCommand comm = new OleDbCommand(sql, conn);

     comm.ExecuteNonQuery(); 
 
     conn.Close();
}

其中 ExecuteNonQuery被成功更改的元組數量,所以 comm.ExecuteNonQuery() 也可以改造為判斷,提示用戶成功或失敗。
 
int i = comm.ExecuteNonQuery();
if (i > 0)
{
      MessageBox.Show("添加數據成功!", "操作提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
      MessageBox.Show("添加失敗!", "操作提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
}

 

3. DataGridView中數據更改的保存

 
private void saveData2()
{
     dataGridView1.EndEdit();
 
     string sql = "select * from 表名";
 
     OleDbDataAdapter da = new OleDbDataAdapter(sql, conn);
 
     OleDbCommandBuilder bld = new OleDbCommandBuilder(da);
     da.UpdateCommand = bld.GetUpdateCommand();
 
        //把DataGridView賦值給dataTbale。(DataTable)的意思是類型轉換,前提是后面緊跟着的東西要能轉換成dataTable類型
     DataTable dt = (DataTable)dataGridView1.DataSource; 
 
     da.Update(dt);
     dt.AcceptChanges();
 
     conn.Close(); 
}

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM