ASP.NET[C#]的ACCESS数据库操作类

  //网上很多都是操作SQL SER 的,整理了一下,不是很完善,但不影响使用,呵呵……

      
// private string datapatch = ConfigurationSettings.AppSettings["acessconn"]; // 数据库地址
                                   
       
private string datapatch = " db/global.asa " ; // 数据库地址
        ///
       
/// 取得dataset
       
///
       
/// 查询语句
       
///
        public   DataSet GetDataSet( string Commandtext)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
                  
" Data Source= " + Server.MapPath(datapatch);
           
string strCommandText = Commandtext;

            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();

            myAdpater.Fill(myDataset);
           
            myConnection.Close();
           
return myDataset;
        }
       
///
       
/// 取得表
       
///
       
/// 查询语句
       
///
        public   DataTable GetDataTable( string Commandtext)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);
           
string strCommandText = Commandtext;

            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();

            myAdpater.Fill(myDataset);

            DataTable mytable
= myDataset.Tables[ 0 ];

            myConnection.Close();
           
return mytable;
        }
       
///
       
/// 取得某行的某列的值
       
///
       
/// 列的名称
       
/// 所属表名
       
/// 表的主键
       
/// 列所属的主键值
       
///
        public   string GetDataColum( string strColumnName, string strTableName, string strColumnkey, string strColumnValue)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);
           
string strCommandText = " select " + strColumnName + " , " + strColumnkey + " from " + strTableName;
           
            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();

            myAdpater.MissingSchemaAction
= MissingSchemaAction.AddWithKey;
           
            myAdpater.Fill(myDataset);
           
            myConnection.Close();
           
            DataTable mytable
= myDataset.Tables[ 0 ];
            DataRow mydr
= mytable.Rows.Find(strColumnValue);
           
string mydc = mydr[strColumnName].ToString();
           
           
           
return mydc;
        }
       

       
///
       
/// 更新某个字段
       
///
       
/// 要更新字段名称
       
/// 要更新的值
       
/// 所属表名称
       
/// 表中KEY
       
/// 表中KEY的值
        public   void UpdateColum( string strColumnName, string strValue, string strTableName, string strColumnKey, string strColumnValue)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);
           
string strCommandText = " select " + strColumnKey + " , " + strColumnName + " from " + strTableName;
           
            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();
           
           
            myAdpater.MissingSchemaAction
= MissingSchemaAction.AddWithKey;

            myAdpater.Fill(myDataset,strTableName);
           
            DataRow drFindRow
= myDataset.Tables[strTableName].Rows.Find(strColumnValue);

            drFindRow[strColumnName]
= strValue;
           
           
           
            myAdpater.Update(myDataset,strTableName);
           
            myConnection.Close();
           
        }

       
///
       
/// 添加行
       
///
       
/// 此行中的字段集合
       
/// 此行中的字段集合的对应值
       
/// 所属表名称
       
/// 表中主键

       
public   void AddRow( string []columns, string []columnvalue, string strTableName, string strColumnKey)
        {       
           
           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);

           
string strColumnCount = "" ;
           
foreach ( string thiscolunmname in columns)
            {
                strColumnCount
= thiscolunmname + " , " + strColumnCount;
            }

           
string strCommandText = " select " + strColumnCount + strColumnKey + " from " + strTableName;
           
            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();
           
           
            myAdpater.Fill(myDataset,strTableName);
       
            DataRow newrow
= myDataset.Tables[strTableName].NewRow();
           
           
for ( int i = 0 ;i < columns.Length;i ++ )
            {
               
string strColumnName = columns[i].ToString();

                newrow[strColumnName]
= columnvalue[i].ToString();
            }
               
           
            myDataset.Tables[strTableName].Rows.Add(newrow);
           
            myAdpater.Update(myDataset,strTableName);
           
            myConnection.Close();
           
        }
///
/// 更新数据行
///
/// 要更新的列集合
/// 要更新的列集合的对应值
/// 所属表名称
/// 表主键
/// 行所属的ID
        public   void updateRow( string []columns, string []columnvalue, string strTableName, string strColumnKey, string strColumnValue)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);

           
string strColumnCount = "" ;
           
foreach ( string thiscolunmname in columns)
            {
                strColumnCount
= thiscolunmname + " , " + strColumnCount;
            }

           
string strCommandText = " select " + strColumnCount + strColumnKey + " from " + strTableName;
           
            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();
           
            myAdpater.MissingSchemaAction
= MissingSchemaAction.AddWithKey;
            myAdpater.Fill(myDataset,strTableName);
       
            DataRow updaterow
= myDataset.Tables[strTableName].Rows.Find(strColumnValue);
           
           
for ( int i = 0 ;i < columns.Length;i ++ )
            {
               
string strColumnName = columns[i].ToString();

                updaterow[strColumnName]
= columnvalue[i].ToString();
            }
           
           
            myAdpater.Update(myDataset,strTableName);
           
            myConnection.Close();
           
        }

 
       
///
       
/// 删除行
       
///
       
/// 所属表
       
/// 主键字段名
       
/// 此行主键值
        public   void delectRow( string strTableName, string strColumnKey, string strColumnValue)
        {       

           
string strConnection = " Provider=Microsoft.Jet.OLEDB.4.0; " +
               
" Data Source= " + Server.MapPath(datapatch);


           
string strCommandText = " select " + strColumnKey + " from " + strTableName;
           
            OleDbConnection myConnection
= new OleDbConnection(strConnection);
            myConnection.Open();

            OleDbDataAdapter myAdpater
= new OleDbDataAdapter(strCommandText,myConnection);

            OleDbCommandBuilder myBuilder
= new OleDbCommandBuilder(myAdpater);

            DataSet myDataset
= new DataSet();
           
            myAdpater.MissingSchemaAction
= MissingSchemaAction.AddWithKey;
            myAdpater.Fill(myDataset,strTableName);
       
            DataRow newrow
= myDataset.Tables[strTableName].Rows.Find(strColumnValue);
           
            newrow.Delete();
           
            myAdpater.Update(myDataset,strTableName);
           
            myConnection.Close();
           
        }
// ----------------------------------------------------------------------------------
     
   
 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand来执行Sql语句: OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的AccessDBUtil,AccessPageUtil,Page 代码这里下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问可以在Web环境下使用。 本例程演示了: 1.Access数据库的插入,更新,修改,查询; 2.带参数的sql语句的使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(未测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值