c# mysql修改_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();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值