c#操作Access[上]

 

看到CSDN上不断兄弟姐妹提问关于c#操作Access的问题,于是本人利用闲暇将c#操作Access的方法加以总结,主要解决的问题有:
创建mdb
创建table
读取table内容
查询table中的内容
向table中插入数据
删除table中的记录
向table中插入照片
读取table中的照片等。
另:本人水平有限,不当之处还请斧正。废话少说,开始正题。

文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。C#的ADO.NET还不能通过编程方式创建全新的ACCESS(MDB)数据库,所以还只能使用ADOX这个来自COM的链接库来操作。
主要知识点如下:
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();

 

1.创建mdb库,例程如下: <script type="text/JavaScript"></script> <script src="http://a.alimama.cn/inf.js" type="text/javascript"></script>


需要注意的是:参数mdbPath是mdb的完整路径(不包含表的名称)。例如:D://test.mdb

  1.         //创建mdb
  2.         public static bool CreateMDBDataBase(string mdbPath)
  3.         {
  4.             try
  5.             {
  6.                 ADOX.CatalogClass cat = new ADOX.CatalogClass();
  7.                 cat.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath + ";");
  8.                 cat = null;
  9.                 return true;
  10.             }
  11.             catch { return false; }
  12.         }

2.创建具体的表,例程如下:
通常一个mdb的可以包含n个表。下面的程序主要是创建一个table。

  1.         //新建mdb的表
  2.         //mdbHead是一个ArrayList,存储的是table表中的具体列名。
  3.         public static bool CreateMDBTable(string mdbPath,string tableName, ArrayList mdbHead)
  4.         {
  5.             try
  6.             {
  7.                 ADOX.CatalogClass cat = new ADOX.CatalogClass();
  8.                 string sAccessConnection
  9.                     = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;
  10.                 ADODB.Connection cn = new ADODB.Connection();
  11.                 cn.Open(sAccessConnection, nullnull, -1);
  12.                 cat.ActiveConnection = cn;
  13.                 //新建一个表
  14.                 ADOX.TableClass tbl = new ADOX.TableClass();
  15.                 tbl.ParentCatalog = cat;
  16.                 tbl.Name = tableName;
  17.                 int size = mdbHead.Count;
  18.                 for (int i = 0; i < size; i++)
  19.                 {
  20.                     //增加一个文本字段
  21.                     ADOX.ColumnClass col2 = new ADOX.ColumnClass();
  22.                     col2.ParentCatalog = cat;
  23.                     col2.Name = mdbHead[i].ToString();//列的名称
  24.                     col2.Properties["Jet OLEDB:Allow Zero Length"].Value = false;
  25.                     tbl.Columns.Append(col2, ADOX.DataTypeEnum.adVarWChar, 500);
  26.                 }
  27.                 cat.Tables.Append(tbl);   //这句把表加入数据库(非常重要)
  28.                 tbl = null;
  29.                 cat = null;
  30.                 cn.Close();
  31.                 return true;
  32.             }
  33.             catch { return false; }
  34.         }

3.读取mdb内容(完全读取),例程如下:
本例程返回的是一个DataTable,如需其他格式可以自行转换。

  1.         // 读取mdb数据
  2.         public static DataTable ReadAllData(string tableName, string mdbPath,ref bool success)
  3.         {
  4.             DataTable dt = new DataTable();
  5.             try
  6.             {
  7.                 DataRow dr;
  8.                 //1、建立连接
  9.                 string strConn
  10.                     = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath + ";Jet OLEDB:Database 
  11. Password=haoren";
  12.                 OleDbConnection odcConnection = new OleDbConnection(strConn);
  13.                 //2、打开连接
  14.                 odcConnection.Open();
  15.                 //建立SQL查询
  16.                 OleDbCommand odCommand = odcConnection.CreateCommand();
  17.                 //3、输入查询语句
  18.                 odCommand.CommandText = "select * from " + tableName;
  19.                 //建立读取
  20.                 OleDbDataReader odrReader = odCommand.ExecuteReader();
  21.                 //查询并显示数据
  22.                 int size = odrReader.FieldCount;
  23.                 for (int i = 0; i < size; i++)
  24.                 {
  25.                     DataColumn dc;
  26.                     dc = new DataColumn(odrReader.GetName(i));
  27.                     dt.Columns.Add(dc);
  28.                 }
  29.                 while (odrReader.Read())
  30.                 {
  31.                     dr = dt.NewRow();
  32.                     for (int i = 0; i < size; i++)
  33.                     {
  34.                         dr[odrReader.GetName(i)] = odrReader[odrReader.GetName(i)].ToString();
  35.                     }
  36.                     dt.Rows.Add(dr);
  37.                 }
  38.                 //关闭连接
  39.                 odrReader.Close();
  40.                 odcConnection.Close();
  41.                 success = true;
  42.                 return dt;
  43.             }
  44.             catch
  45.             {
  46.                 success = false;
  47.                 return dt;
  48.             }
  49.         }

4.读取mdb内容(按列读取),例程如下:
columns数组存储的是你要查询的列名称(必须确保mdb表中存在你要的列)

  1.         // 读取mdb数据
  2.         public static DataTable ReadDataByColumns(string mdbPaht,string tableName, string[] columns, ref bool success)
  3.         {
  4.             DataTable dt = new DataTable();
  5.             try
  6.             {
  7.                 DataRow dr;
  8.                 //1、建立连接
  9.                 string strConn
  10.                     = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath + ";Jet OLEDB:Database Password=haoren";
  11.                 OleDbConnection odcConnection = new OleDbConnection(strConn);
  12.                 //2、打开连接
  13.                 odcConnection.Open();
  14.                 //建立SQL查询
  15.                 OleDbCommand odCommand = odcConnection.CreateCommand();
  16.                 //3、输入查询语句
  17.                 string strColumn = "";
  18.                 for (int i = 0; i < columns.Length; i++)
  19.                 {
  20.                     strColumn += columns[i].ToString() + ",";
  21.                 }
  22.                 strColumn = strColumn.TrimEnd(',');
  23.                 odCommand.CommandText = "select "+strColumn+" from " + tableName;
  24.                 //建立读取
  25.                 OleDbDataReader odrReader = odCommand.ExecuteReader();
  26.                 //查询并显示数据
  27.                 int size = odrReader.FieldCount;
  28.                 for (int i = 0; i < size; i++)
  29.                 {
  30.                     DataColumn dc;
  31.                     dc = new DataColumn(odrReader.GetName(i));
  32.                     dt.Columns.Add(dc);
  33.                 }
  34.                 while (odrReader.Read())
  35.                 {
  36.                     dr = dt.NewRow();
  37.                     for (int i = 0; i < size; i++)
  38.                     {
  39.                         dr[odrReader.GetName(i)] = odrReader[odrReader.GetName(i)].ToString();
  40.                     }
  41.                     dt.Rows.Add(dr);
  42.                 }
  43.                 //关闭连接
  44.                 odrReader.Close();
  45.                 odcConnection.Close();
  46.                 success = true;
  47.                 return dt;
  48.             }
  49.             catch
  50.             {
  51.                 success = false;
  52.                 return dt;
  53.             }
  54.         }

http://blog.csdn.net/gisfarmer/

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值