【总结】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(); 

}

 

 

 

你可能感兴趣的:(Access)