zoukankan      html  css  js  c++  java
  • 【总结】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(); 
    }
  • 相关阅读:
    iOS获取设备UUID和IDFA
    iOS之Xcode提交App中断出现:Cannot proceed with delivery: an existing transporter instance is currently uploading this package
    iOS 打测试包给测试人员测试,两种安装方式
    ios APP进程杀死之后和APP在后台接收到推送点击跳转到任意界面处理
    iOS中统计平台的使用
    Android APK反编译
    Linux客户端、服务器、窗口管理器的关系
    Linux中ctrl-c, ctrl-z, ctrl-d 区别
    如何下载百度网盘已失效资源链接
    svn 批量更新 bat脚本
  • 原文地址:https://www.cnblogs.com/MyateJx/p/3502385.html
Copyright © 2011-2022 走看看