当前位置:  编程技术>.net/c#/asp.net

C# Access数据库增删查改的简单方法

    来源: 互联网  发布时间:2014-10-26

    本文导语:  引用集: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.和查询有关的...

引用集:
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();
}

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请问谁有Applet连接远程Access数据库并且显示数据库内容的例子!
  • 在vj++里怎样连接access数据库(菜鸟问题)
  • 怎么样把数据库中查出的数据存为ACCESS文件?(六点之前在线)
  • 在Linuex下如何访问windows平台下的access数据库?
  • access2000数据库中单精度型的数据是对应double还是float型???
  • 数据库用access需要驱动吗?
  • 关于JSP 与 Access数据库的问题
  • php怎么连接access数据库
  • 从Access数据库读大块数据问题,为什么5119字节左右是极限,怎么解决??
  • 请问Access数据库中的日期型字段是对应java中的哪个Date类?
  • unix系统有没有本地数据库?类似windows下的access
  • 访问Access数据库,除了JDBD-ODBC桥,是否还有别的办法?
  • 关于JDBC-ODBC连接ACCESS数据库的问题(不设置数据源)? iis7站长之家
  • 如何将客户端上传的ACCESS数据库用ODBC连接,即动态ODBC,急盼!
  • 在JSP中,不使用ODBC,如何连接到ACCESS数据库?
  • 关于JDBC-ODBC连接ACCESS数据库的问题(不设置数据源)?
  • 将Access 2000数据库转移到Oracle 9i
  • Java 的Access 数据库操作库 Jackcess
  • 有人知道linux怎么能访问局域网中的一台带有MS Access数据库的主机?
  • applet如何实现对数据库(access)的操作,征求设计方案。
  • java命名空间javax.print.attribute.standard类jobstatereason的类成员方法: document_access_error定义及介绍
  • Tomcat access log记录到mongo的插件 Tomcat Mongo Access Log Valve
  • nginx_limit_access_module
  • Microsoft Access的开源JDBC驱动 UCanAccess
  • SUMO Access Manager
  • SVN Access Manager
  • 请问有没有 for access 的 jdbc driver?
  • linux下面,怎么连接access呀,
  • 请问,linux下能用access吗?
  • asp程序使用的access在Linux下如何使用!
  • 信息系统访问权限控制 Access Road


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3