C# 操作 access 数据库的实例代码

 更新时间:2018年03月26日 16:14:50   作者:房上的猫  
这篇文章主要介绍了C# 操作 access 数据库的实例代码,需要的朋友可以参考下

随笔:

(1)   命名空间

            using System.Data.OleDb;

(2)   连接字符串           

private staticstring connStr = @"Provider= Microsoft.Ace.OLEDB.12.0;Data Source = d:\login.accdb";

            注意:

             a、DataSource = 数据库存放的路径(这里数据库放到了D盘目录下)
             b、 2003版本的Access数据库链接字符串: 

 privatestatic stringconnStr =@"Provider = Microsoft.Jet.OLEDB.4.0;DataSource = d:\login.mdb";
          2007版本的Access数据库链接字符串:privatestaticstring connStr =@"Provider= Microsoft.Ace.OLEDB.12.0;Data Source = d:\login.accdb";

(3)   建立连接:           

OleDbConnection tempconn =new OleDbConnection(connStr);

(4)   使用OleDbCommand类来执行Sql语句:      

 OleDbCommand cmd = new OleDbCommand(sql, tempconn); 
      tempconn.Open();
      cmd.ExecuteNonQuery();

栗子(工具类):

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.OleDb;
using System.Windows.Forms;
using System.Data;
namespace test
{
  class AccessHelper
  {
    private static string connStr = @"Provider = Microsoft.Ace.OLEDB.12.0;Data Source = d:\login.accdb";
    public static OleDbConnection GetConn()
    {
      OleDbConnection tempconn = new OleDbConnection(connStr);
      MessageBox.Show(tempconn.DataSource);
      tempconn.Open();
      MessageBox.Show(tempconn.State.ToString());
      return (tempconn);
    }
    /// <summary>
    /// 执行增加、删除、修改指令
    /// </summary>
    /// <param name="sql">增加、删除、修改的sql语句</param>
    /// <param name="param">sql语句的参数</param>
    /// <returns></returns>
    public static int ExecuteNonQuery(string sql, params OleDbParameter[] param)
    {
      using (OleDbConnection conn = new OleDbConnection(connStr))
      {
        using (OleDbCommand cmd = new OleDbCommand(sql,conn))
        {
          if (param != null)
          {
            cmd.Parameters.AddRange(param);
          }
          conn.Open();
          return(cmd.ExecuteNonQuery());
        }
      }
    }
    /// <summary>
    /// 执行查询指令,获取返回的首行首列的值
    /// </summary>
    /// <param name="sql">查询sql语句</param>
    /// <param name="param">sql语句的参数</param>
    /// <returns></returns>
    public static object ExecuteScalar(string sql, params OleDbParameter[] param)
    {
      using (OleDbConnection conn = new OleDbConnection(connStr))
      {
        using (OleDbCommand cmd = new OleDbCommand(sql, conn))
        {
          if (param != null)
          {
            cmd.Parameters.AddRange(param);
          }
          conn.Open();
          return (cmd.ExecuteScalar());
        }
      }
    }
    /// <summary>
    /// 执行查询指令,获取返回的datareader
    /// </summary>
    /// <param name="sql">查询sql语句</param>
    /// <param name="param">sql语句的参数</param>
    /// <returns></returns>
    public static OleDbDataReader ExecuteReader(string sql, params OleDbParameter[] param)
    {
      OleDbConnection conn = new OleDbConnection(connStr);
      OleDbCommand cmd = conn.CreateCommand();
      cmd.CommandText = sql;
      cmd.CommandType = CommandType.Text;
      if (param != null)
      {
        cmd.Parameters.AddRange(param);
      }
      conn.Open();
      return (cmd.ExecuteReader(CommandBehavior.CloseConnection));
    }
    /// <summary>
    /// 执行查询指令,获取返回datatable
    /// </summary>
    /// <param name="sql">查询sql语句</param>
    /// <param name="param">sql语句的参数</param>
    /// <returns></returns>
    public static DataTable ExecuteDatable(string sql, params OleDbParameter[] param)
    {
      using (OleDbConnection conn = new OleDbConnection(connStr))
      {
        using (OleDbCommand cmd = new OleDbCommand(sql, conn))
        {
          if (param != null)
          {
            cmd.Parameters.AddRange(param);
          }
          DataTable dt = new DataTable();
          OleDbDataAdapter sda = new OleDbDataAdapter(cmd);
          sda.Fill(dt);
          return (dt);
        }
      }
    }
  }
}

总结

以上所述是小编给大家介绍的C# 操作 access 数据库的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • C#中ref和out的区别浅析

    C#中ref和out的区别浅析

    这篇文章主要介绍了C#中ref和out的区别浅析,当一个方法需要返回多个值的时候,就需要用到ref和out,那么这两个方法区别在哪儿呢,需要的朋友可以参考下
    2015-01-01
  • 经典实例讲解C#递归算法

    经典实例讲解C#递归算法

    这篇文章主要用实例讲解C#递归算法的概念以及用法,文中代码非常详细,帮助大家更好的参考和学习,感兴趣的朋友可以了解下
    2020-06-06
  • C#影院售票系统毕业设计(3)

    C#影院售票系统毕业设计(3)

    这篇文章介绍了C#影院售票系统毕业设计,文章主要内容是关于购票、座位颜色状态的改变及场次座位状态的显示,需要的朋友可以参考下
    2015-11-11
  • C#隐藏控制台键盘输入的方法

    C#隐藏控制台键盘输入的方法

    这篇文章主要介绍了C#隐藏控制台键盘输入的方法,涉及C#针对系统底层调用的相关技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • C#实现多个计时器记录不同定时时间

    C#实现多个计时器记录不同定时时间

    这篇文章主要为大家详细介绍了C#实现多个计时器记录不同定时时间,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • C#中数组Array,ArrayList,泛型List详细对比

    C#中数组Array,ArrayList,泛型List详细对比

    关于数组Array,ArrayList,泛型List,简单的说数组就是值对象,它存储数据元素类型的值的一系列位置.Arraylist和list可以提供添加,删除,等操作的数据. 具体如何进行选择使用呢,我们来详细探讨下
    2016-06-06
  • Unity实现3D射箭小游戏

    Unity实现3D射箭小游戏

    这篇文章主要为大家详细介绍了Unity实现3D射箭小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • VsCode使用EmmyLua插件调试Unity工程Lua代码的详细步骤

    VsCode使用EmmyLua插件调试Unity工程Lua代码的详细步骤

    这篇文章主要介绍了VsCode使用EmmyLua插件调试Unity工程Lua代码,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • C# Entity Framework中的IQueryable和IQueryProvider详解

    C# Entity Framework中的IQueryable和IQueryProvider详解

    这篇文章主要介绍了C# Entity Framework中的IQueryable和IQueryProvider详解,本文使用实例分析这两个接口的内部实现,需要的朋友可以参考下
    2015-01-01
  • C#实现ComboBox变色的示例代码

    C#实现ComboBox变色的示例代码

    这篇文章主要为大家详细介绍了C#如何实现ComboBox变色的效果,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-01-01

最新评论