C#操作Access类


using System;   

using System.Data;   

using System.Data.OleDb;   

   

namespace AccessDb   

{   

    /** <summary>   

    /// AccessDb 的摘要说明,以下信息请完整保留   

    /// 请在数据传递完毕后调用Close()方法,关闭数据链接。   

    /// </summary>   

    public class AccessDbClass   

    {   

   

        变量声明处#region 变量声明处   

        public OleDbConnection Conn;   

        public string ConnString;//连接字符串  

        #endregion   

   

   

        构造函数与连接关闭数据库#region 构造函数与连接关闭数据库   

        /** <summary>   

        /// 构造函数   

        /// </summary>   

        /// <param name="Dbpath">ACCESS数据库路径</param>   

        public AccessDbClass(string Dbpath)   

        {   

            ConnString = "Provider=Microsoft.Jet.OleDb.4.0;Data Source=";   

            ConnString += Dbpath;   

            Conn = new OleDbConnection(ConnString);   

            Conn.Open();   

        }   

   

        /** <summary>   

        /// 打开数据源链接   

        /// </summary>   

        /// <returns></returns>   

        public OleDbConnection DbConn()   

        {   

            Conn.Open();   

            return Conn;   

        }   

   

        /** <summary>   

        /// 请在数据传递完毕后调用该函数,关闭数据链接。   

        /// </summary>   

        public void Close()   

        {   

            Conn.Close();   

        }  

        #endregion   

   

   

        数据库基本操作#region 数据库基本操作   

        /** <summary>   

        /// 根据SQL命令返回数据DataTable数据表,   

        /// 可直接作为dataGridView的数据源   

        /// </summary>   

        /// <param name="SQL"></param>   

        /// <returns></returns>   

        public DataTable SelectToDataTable(string SQL)   

        {   

            OleDbDataAdapter adapter = new OleDbDataAdapter();   

            OleDbCommand command = new OleDbCommand(SQL, Conn);   

            adapter.SelectCommand = command;   

            DataTable Dt = new DataTable();   

            adapter.Fill(Dt);      

            return Dt;   

        }   

   

        /** <summary>   

        /// 根据SQL命令返回数据DataSet数据集,其中的表可直接作为dataGridView的数据源。   

        /// </summary>   

        /// <param name="SQL"></param>   

        /// <param name="subtableName">在返回的数据集中所添加的表的名称</param>   

        /// <returns></returns>   

        public DataSet SelectToDataSet(string SQL, string subtableName)   

        {   

            OleDbDataAdapter adapter = new OleDbDataAdapter();   

            OleDbCommand command = new OleDbCommand(SQL, Conn);   

            adapter.SelectCommand = command;   

            DataSet Ds = new DataSet();   

            Ds.Tables.Add(subtableName);   

            adapter.Fill(Ds, subtableName);   

            return Ds;   

        }   

   

        /** <summary>   

        /// 在指定的数据集中添加带有指定名称的表,由于存在覆盖已有名称表的危险,返回操作之前的数据集。   

        /// </summary>   

        /// <param name="SQL"></param>   

        /// <param name="subtableName">添加的表名</param>   

        /// <param name="DataSetName">被添加的数据集名</param>   

        /// <returns></returns>   

        public DataSet SelectToDataSet (string SQL, string subtableName, DataSet DataSetName)   

        {   

            OleDbDataAdapter adapter = new OleDbDataAdapter();   

            OleDbCommand command = new OleDbCommand(SQL, Conn);   

            adapter.SelectCommand = command;   

            DataTable Dt = new DataTable();   

            DataSet Ds = new DataSet();   

            Ds = DataSetName;   

            adapter.Fill(DataSetName, subtableName);   

            return Ds;   

        }   

   

        /** <summary>   

        /// 根据SQL命令返回OleDbDataAdapter,   

        /// 使用前请在主程序中添加命名空间System.Data.OleDb   

        /// </summary>   

        /// <param name="SQL"></param>   

        /// <returns></returns>   

        public OleDbDataAdapter SelectToOleDbDataAdapter(string SQL)   

        {   

            OleDbDataAdapter adapter = new OleDbDataAdapter();   

            OleDbCommand command = new OleDbCommand(SQL, Conn);   

            adapter.SelectCommand = command;   

            return adapter;   

        }   

   

        /** <summary>   

        /// 执行SQL命令,不需要返回数据的修改,删除可以使用本函数   

        /// </summary>   

        /// <param name="SQL"></param>   

        /// <returns></returns>   

        public bool ExecuteSQLNonquery(string SQL)   

        {   

            OleDbCommand cmd = new OleDbCommand(SQL, Conn);   

            try 

            {   

                cmd.ExecuteNonQuery();   

                return true;   

            }   

            catch 

            {   

                return false;   

            }   

        }  

        #endregion   

    }   

}  

使用例子:


 

using AccessDb; 
... 
//初始化,载入数据库路径 
AccessDbClass mydb = new AccessDbClass("c:/db.mdb"); 

//返回符合SQL要求的DataTable,并且与控件dataGridView1绑定 
DataTable dt = new DataTable(); 
dt = mydb.SelectToDataTable(@"select * from student"); 
this.dataGridView1.DataSource = dt; 

//返回DataSet,其中包括一个符合SQL要求和给定名称的DataTable,并且与控件dataGridView1绑定 
DataSet ds = new DataSet(); 
ds = mydb.SelectToDataSet(@"select * from student","student"); 
this.dataGridView1.DataSource = ds.Tables["student"]; 

//关闭数据库 
mydb.Close();


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值