您好,登錄后才能下訂單哦!
小編給大家分享一下C#操作Access之如何按列讀取mdb,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
C#的ADO.NET還不能通過編程方式創(chuàng)建全新的ACCESS(MDB)數(shù)據(jù)庫,所以還只能使用ADOX這個(gè)來自COM的鏈接庫來操作。
C#操作Access主要知識(shí)點(diǎn)如下:
using System.Data.OleDb; using System.Data;
C#操作Access連接字符串:
String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=product.mdb";
C#操作Access建立連接:
OleDbConnection connection = new OleDbConnection(connectionString);
C#操作Access使用OleDbCommand類來執(zhí)行Sql語句:
OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery();
C#操作Access之按列讀取mdb內(nèi)容實(shí)例如下:
columns數(shù)組存儲(chǔ)的是你要查詢的列名稱(必須確保mdb表中存在你要的列)
// 讀取mdb數(shù)據(jù) public static DataTable ReadDataByColumns(string mdbPaht,string tableName, string[] columns, ref bool success) { DataTable dt = new DataTable(); try { DataRow dr; //1、建立連接 C#操作Access之按列讀取mdb string strConn = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath + ";Jet OLEDB:Database Password=haoren"; OleDbConnection odcConnection = new OleDbConnection(strConn); //2、打開連接 C#操作Access之按列讀取mdb odcConnection.Open(); //建立SQL查詢 OleDbCommand odCommand = odcConnection.CreateCommand(); //3、輸入查詢語句 string strColumn = ""; for (int i = 0; i < columns.Length; i++) { strColumn += columns[i].ToString() + ","; } strColumn = strColumn.TrimEnd(','); odCommand.CommandText = "select "+strColumn+" from " + tableName; //建立讀取 C#操作Access之按列讀取mdb OleDbDataReader odrReader = odCommand.ExecuteReader(); //查詢并顯示數(shù)據(jù) C#操作Access之按列讀取mdb int size = odrReader.FieldCount; for (int i = 0; i < size; i++) { DataColumn dc; dc = new DataColumn(odrReader.GetName(i)); dt.Columns.Add(dc); } while (odrReader.Read()) { dr = dt.NewRow(); for (int i = 0; i < size; i++) { dr[odrReader.GetName(i)] = odrReader[odrReader.GetName(i)].ToString(); } dt.Rows.Add(dr); } //關(guān)閉連接 C#操作Access之按列讀取mdb odrReader.Close(); odcConnection.Close(); success = true; return dt; } catch { success = false; return dt; } }
看完了這篇文章,相信你對(duì)“C#操作Access之如何按列讀取mdb”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。