C#访问Access数据类

本文介绍如何在web.config文件中配置数据库连接字符串,并使用C#代码通过OleDb进行数据库操作,包括执行SQL语句、获取数据集及读取数据等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

配置web.config文件的链接参数


<configuration>

  <appSettings>
    <add key="connStr" value="/App_Data/abc.mdb" />
  </appSettings>
    <connectionStrings/>


C#代码

 

using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.OleDb;

namespace Conn
{
    
public class ConnDB
    
{
        
/// <summary>
        
/// 连接数据库字符串
        
/// </summary>

        private string connectionString;

        
/// <summary>
        
/// 存储数据库连接(保护类,只有由它派生的类才能访问)
        
/// </summary>

        protected OleDbConnection Connection;

        
/// <summary>
        
/// 构造函数:数据库的默认连接
        
/// </summary>

        public ConnDB()
        
{
            
string connStr;
            connStr 
= System.Configuration.ConfigurationSettings.AppSettings["connStr"]; //从web.config配置中读取

            connectionString 
= "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Common.applicationPath + connStr;

            Connection 
= new OleDbConnection(connectionString);
        }


        
/// <summary>
        
/// 构造函数:带有参数的数据库连接
        
/// </summary>
        
/// <param name="newConnectionString">连接语句</param>

        public ConnDB(string newConnectionString)
        
{
            connectionString 
= "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Common.applicationPath + newConnectionString;
            Connection 
= new OleDbConnection(connectionString);
        }


        
/// <summary>
        
/// 获得连接字符串
        
/// </summary>

        public string ConnectionString
        
{
            
get return connectionString; }
        }



        
/// <summary>
        
/// 执行SQL语句没有返回结果,如:执行删除、更新、插入等操作
        
/// </summary>
        
/// <param name="strSQL">SQL语句</param>
        
/// <returns>是否成功</returns>

        public bool ExeSQL(string strSQL)
        
{
            
bool resultState = false;
            OleDbTransaction myTrans 
= null;
            OleDbCommand command 
= null;

            
try
            
{
                Connection.Open();
                myTrans 
= Connection.BeginTransaction();
                command 
= new OleDbCommand(strSQL, Connection, myTrans);
                command.ExecuteNonQuery();
                myTrans.Commit();
                resultState 
= true;
            }

            
catch
            
{
                
if (myTrans != null)
                    myTrans.Rollback();
                resultState 
= false;
            }

            
finally
            
{
                Connection.Close();
            }

            
return resultState;
        }


        
/// <summary>
        
/// 执行SQL语句返回结果到DataReader中
        
/// </summary>
        
/// <param name="strSQL">SQL语句</param>
        
/// <returns>DataReader</returns>

        public OleDbDataReader ReturnDataReader(string strSQL)
        
{
            OleDbDataReader dataReader 
= null;
            
try
            
{
                Connection.Open();
                OleDbCommand command 
= new OleDbCommand(strSQL, Connection);
                dataReader 
= command.ExecuteReader();
            }

            
catch
            
{
                Connection.Close();
            }

            
return dataReader;
        }


        
/// <summary>
        
/// 执行SQL语句返回结果到DataSet中
        
/// </summary>
        
/// <param name="strSQL">SQL语句</param>
        
/// <returns>DataSet</returns>

        public DataSet ReturnDataSet(string strSQL)
        
{
            DataSet dataSet 
= null;
            
try
            
{
                Connection.Open();
                dataSet 
= new DataSet();
                OleDbDataAdapter OleDbDA 
= new OleDbDataAdapter(strSQL, Connection);
                OleDbDA.Fill(dataSet, 
"objDataSet");
            }

            
finally
            
{
                Connection.Close();
            }

            
return dataSet;
        }


        
/// <summary>
        
/// 执行一查询语句,同时返回查询结果数目
        
/// </summary>
        
/// <param name="strSQL">SQL语句</param>
        
/// <returns>结果数</returns>

        public int ReturnSqlResultCount(string strSQL)
        
{
            
int sqlResultCount = 0;

            
try
            
{
                Connection.Open();
                OleDbCommand command 
= new OleDbCommand(strSQL, Connection);
                OleDbDataReader dataReader 
= command.ExecuteReader();

                
while (dataReader.Read())
                
{
                    sqlResultCount
++;
                }

                dataReader.Close();
            }

            
catch
            
{
                sqlResultCount 
= 0;
            }

            
finally
            
{
                Connection.Close();
            }

            
return sqlResultCount;
        }


        
/// <summary>
        
/// 关闭连接
        
/// </summary>

        public void close()
        
{
            
if (Connection != null)
                Connection.Close();
        }

    }

}

using System; using System.Data; using System.Configuration; using System.Data.OleDb; namespace xxxxx { /// <summary> /// Access数据库访问类 /// </summary> public class DataAccess { private static OleDbConnection conn = new OleDbConnection(); private static OleDbCommand comm = new OleDbCommand(); private static string asscessPath = @".\PoliScan.mdb"; /// <summary> /// 设置Access数据库路径 /// </summary> /// <param name="path">完整的路径字符串</param> public static void SetAccessPath(string path) { asscessPath = path; } /// <summary> /// 打开数据库 /// </summary> /// <returns>成功返回 true;失败返回 false;异常时抛出异常</returns> public static bool OpenConnection() { bool retval = false; if (conn.State != ConnectionState.Open) { conn.ConnectionString = @"Provider=Microsoft.Jet.OleDb.4.0;Data Source=" + asscessPath; comm.Connection = conn; try { conn.Open(); if (conn.State == ConnectionState.Open) { retval = true; } } catch (Exception e) { throw new Exception(e.Message); } ............................ ............................ using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using System.Data.OleDb; using System.Data.SqlClient; /// <summary> /// DataBase 的摘要说明 /// </summary> public class DataBase : IDisposable { public DataBase() { // // TODO: 在此处添加构造函数逻辑 // } private SqlConnection con; //创建连接对象 #region 打开数据库连接 /// <summary> /// 打开数据库连接. /// </summary> private void Open() { // 打开数据库连接 if (con == null) { con = new SqlConnection("Data Source = . ;Database = CET ;Integrated Security = SSPI "); } if (con.State == System.Data.ConnectionState.Closed) con.Open(); }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值