C# Access数据库增删查改的简单方法
2016-06-01 15:59
369 查看
引用集:
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();
}
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();
}
相关文章推荐
- oracle笔记——索引
- 大话架构师之分布式存储--mysql
- 存档mysql配置文件
- 不直接访问远程的数据库,而是通过中间件(专业DBA的博客)
- oracle系统包—-dbms_output用法
- SQLServer 将日期改造成标准日期格式(如: 2016/6 ->201606)
- oracle中if/else功能的实现的3种写法
- Oracle CASE WHEN 用法介绍
- MongoDB执行计划学习整理
- JDBC连接MySQL
- oracle 游标使用根据工龄更新年假
- 关系表与非关系表的区别
- oracle的基本操作
- oracle 使用case when查询列
- mysql 报错ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing
- 关于MYSQL替换和存储过程的问题、
- c#.net连接mongodb入门(一)
- mongodb如何记录慢查询
- mysql 报错ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executin
- oracle 字段类型详解