C#操作Access之按列读取mdb浅析

C#操作Access之按列读取mdb是如何实现的呢?首先我们来看看基本的知识:本文C#操作Access数据库的基础知识,并提供一个相关的实例。C#的ADO.NET还不能通过编程方式创建全新的ACCESS(MDB)数据库,所以还只能使用ADOX这个来自COM的链接库来操作。

C#操作Access主要知识点如下:

 
 
 
  1. using System.Data.OleDb;  
  2.  
  3. using System.Data; 

C#操作Access连接字符串:

 
 
 
  1. String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;  
  2.  
  3. Data Source=product.mdb"; 

C#操作Access建立连接:

 
 
 
  1. OleDbConnection connection = new OleDbConnection(connectionString); 

C#操作Access使用OleDbCommand类来执行Sql语句:

 
 
 
  1. OleDbCommand cmd = new OleDbCommand(sql, connection);  
  2.  
  3. connection.Open();  
  4.  
  5. cmd.ExecuteNonQuery(); 

C#操作Access之按列读取mdb内容实例如下:

columns数组存储的是你要查询的列名称(必须确保mdb表中存在你要的列)

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

C#操作Access之按列读取mdb的基本内容就向你介绍到这里,希望对你了解和学习C#操作Access之按列读取mdb有所帮助。

【编辑推荐】

  1. C#中操作注册表的五大主键浅析
  2. C#操作注册表常用方法详解
  3. C#操作Access之创建mdb库浅析
  4. C#操作Access之创建表浅析
  5. C#操作Access之读取mdb浅析

网页名称:C#操作Access之按列读取mdb浅析
文章链接:http://www.mswzjz.cn/qtweb/news9/371559.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能