本文實例講述了C#通過oledb訪問access數據庫的方法。分享給大家供大家參考。具體分析如下:
這里演示了如何在 C# 中使用 Microsoft Access 數據庫。包括如何創建數據集并從數據庫向該數據集添加表。
// OleDbSample.cs// 若要從命令行生成此示例,請使用命令:// csc oledbsample.csusing System;using System.Data;using System.Data.OleDb;using System.Xml.Serialization;public class MainClass { public static void Main () { // 設置訪問連接并選擇字符串。 // 如果從命令行生成此示例, // 則必須更改 BugTypes.MDB 的路徑:#if USINGPROJECTSYSTEM string strAccessConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=..//..//BugTypes.MDB";#else string strAccessConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=BugTypes.MDB";#endif string strAccessSelect = "SELECT * FROM Categories"; // 創建數據集并向其中添加 Categories 表: DataSet myDataSet = new DataSet(); OleDbConnection myAccessConn = null; try { myAccessConn = new OleDbConnection(strAccessConn); } catch(Exception ex) { Console.WriteLine("Error: Failed to create a database connection. /n{0}", ex.Message); return; } try { OleDbCommand myAccessCommand = new OleDbCommand(strAccessSelect,myAccessConn); OleDbDataAdapter myDataAdapter = new OleDbDataAdapter(myAccessCommand); myAccessConn.Open(); myDataAdapter.Fill(myDataSet,"Categories"); } catch (Exception ex) { Console.WriteLine("Error: Failed to retrieve the required data from the DataBase./n{0}", ex.Message); return; } finally { myAccessConn.Close(); } // 一個數據集可以包含多個表,因此可以將這些表都放入 // 一個數組中: DataTableCollection dta = myDataSet.Tables; foreach (DataTable dt in dta) { Console.WriteLine("Found data table {0}", dt.TableName); } // 下面兩行顯示兩種不同方法,可用于獲取數據集中 // 的表計數: Console.WriteLine("{0} tables in data set", myDataSet.Tables.Count); Console.WriteLine("{0} tables in data set", dta.Count); // 下面幾行顯示如何按名稱 // 從數據集中獲取特定表的信息: Console.WriteLine("{0} rows in Categories table", myDataSet.Tables["Categories"].Rows.Count); // 列信息自動從數據庫中提取,因此 // 可以在此處看到這些信息: Console.WriteLine("{0} columns in Categories table", myDataSet.Tables["Categories"].Columns.Count); DataColumnCollection drc = myDataSet.Tables["Categories"].Columns; int i = 0; foreach (DataColumn dc in drc) { // 打印列下標,然后打印列的名稱及其 // 數據類型: Console.WriteLine("Column name[{0}] is {1}, of type {2}",i++ , dc.ColumnName, dc.DataType); } DataRowCollection dra = myDataSet.Tables["Categories"].Rows; foreach (DataRow dr in dra) { // 打印 CategoryID 作為下標,然后打印 CategoryName: Console.WriteLine("CategoryName[{0}] is {1}", dr[0], dr[1]); } }}
希望本文所述對大家的C#程序設計有所幫助。
新聞熱點
疑難解答