欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

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

时间:2021-01-06 11:23:17|栏目:.NET代码|点击:

随笔:

(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# 三种序列化方法分享

栏    目:.NET代码

下一篇:asp.net中TextBox只能输入数字的最简洁的两种方法

本文标题:C# 操作 access 数据库的实例代码

本文地址:http://www.codeinn.net/misctech/41410.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有