安全、高速、放心的軟件下載

如何在.NET中訪問MySQL數據庫

時間:2019-05-21 09:21:13來源:www.iimmyzlw.icu人氣:0
歡迎進入.NET社區論壇,與200萬技術人員互動交流 >>進入         引言: 如果你不是只在大集團公司工作過的話,你一定會有機會接觸到MySQL,雖然它并不支持事務處理,存儲過程,但是它提供的功能一定能滿足你的大部分需求,另外,簡潔的MySQL也有一些它獨到的優勢,在有些時候,它的速度甚至超過大型數據庫。 那么如何在.NET中訪問MySQL數據庫呢?也許很多人馬上會說:用OLEDB嘛,但是事實上采用.NET OleDb Data Provider并不能訪問MySQL,如果你使用的話,系統會提示你:Net Data OLE DB 提供程序 (System.Data.Odbc) 不支持 MSDASQL 提供程序(用于 Odbc 驅動程序的 Microsoft OLE DB 提供程序)。,是什么原因我并不知道,按照MySQLDriverCS的作者的說法就是它被abandoned by the owner,呵呵,興許還有些故事。 幸好,我們還有其它的選擇,這里就要介紹兩種訪問MySQL數據庫的辦法。 使用ODBC.NET ODBC.NET(全稱ODBC .NET Data Provider)是一個免費的.NET Framework附加組件,需要到微軟公司的網站上去下載,它需要系統已經安裝MDAC 2.7或者更高版本。另外,還需要安裝MySQL的ODBC驅動程序,還需要在ODBC數據源管理器中配置一下DSN,如下圖所示: 在對象的設計上,ODBC.NET也跟OLEDB,SQL等一樣,分別為OdbcConnection, OdbcCommand, OdbcDataAdapter, OdbcDataReader,用法也完全一樣,如果你希望用ODBC .NET來代替以前的OleDb .NET Data Provider,事實上完全可以通過查找替換的辦法來修改你的程序。 以下是一段代碼示例: try{ string constr = DSN=MySQL; + UID=; +PWD=; ; conn = new OdbcConnection(constr); conn.Open(); string query = insert into test.dbtable values10,disksidkfsdi, asdfaf, adsfasdf); string tmp = null; OdbcCommand cmd = new OdbcCommand(query, conn); for(int i = 0; i < 100000; i++) { cmd.ExecuteNonQuery(); } cmd.Dispose(); conn.Close(); query = select * from test.dbtable; OdbcCommand cmd2 = newOdbcCommand(query, conn); conn.Open(); OdbcDataReader reader = cmd2.ExecuteReader(); while(reader.Read()) { tmp = reader[0].ToString(); tmp = reader[1].ToString(); tmp = reader[2].ToString(); tmp = reader[3].ToString(); } conn.Close(); query = delete from test.dbtable; OdbcCommand cmd3 = newOdbcCommand(query, conn); conn.Open(); cmd3.ExecuteNonQuery(); } catch(Exception ex) { MessageBox.Show(ex.Message); } finally { conn.Close(); }只要是用C#寫過數據庫應用的人一定能知道,上面的代碼執行了十萬次插入數據和讀取數據,最后將數據記錄全部刪除的操作。 使用MySQLDriverCS 可能大部分的人都不知道這個東西,MySQLDriverCS是MySQL數據庫的一個免費開源的.NET驅動程序。和Sql .NET Data Provider是為Sql Server一樣,它是專門為MySQL設計的,可以叫做MySQL .NET Data Provider。使用他不需要額外的去設置ODBC數據源,基本上只要能連接到MySQL就能通過MySQLDriverCS來訪問。 進入MySQLDriverCS是SourceForge.NET上的一個項目,不過不知道什么原因,這個網站在國內訪問不到。 下面是使用MySQLDriverCS的代碼示例: MySQLConnection conn = null;try{ string connstr = Data Source=MySQL;Password=root;User ID=root;Location=localhost; conn = new MySQLConnection(constr); conn.Open(); string query = insert into test.dbtable values(10, disksidkfsdi, asdfaf, adsfasdf); string tmp = null; MySQLCommand cmd = new MySQLCommand(query, conn); for(int i = 0; i < 100000; i++) { cmd.ExecuteNonQuery(); } cmd.Dispose(); conn.Close(); query = select * from test.dbtable; MySQLCommand cmd2 = new MySQLCommand(query, conn); conn.Open(); MySQLDataReader reader = cmd2.ExecuteReaderEx(); while(reader.Read()) { tmp = reader[0].ToString(); tmp = reader[1].ToString(); tmp = reader[2].ToString(); tmp = reader[3].ToString(); } conn.Close(); query = delete from test.dbtable; MySQLCommand cmd3 = new MySQLCommand(query, conn); conn.Open(); cmd3.ExecuteNonQuery();}catch(Exception ex){ MessageBox.Show(ex.Message);}finally{ conn.Close(); } 和上面的那段代碼幾乎一模一樣,所不同的是Odbc變成了MySQL,另外,需要注意的一點是Command的ExecuteReader方法在MySQLDriverCS中變成了ExecuteReaderEx,還有些細微的差別請參考附帶的文檔詳細的介紹。 性能測試 有些讀者其實已經看出來我以上寫的那段代碼的用意,對了,其實目的就是用來進行性能測試的。以上兩段代碼的執行時間分別是:ODBC.NET為24秒左右,MySQLDriverCS為17秒左右。結果并不出人意外,作為MySQL的專用數據驅動程序,MySQLDriverCS的速度大大快于ODBC.NET是在情理之中的。 總結 本文介紹了兩種MySQL數據庫訪問的方法,同時對它們的性能做了一個簡單的測試,希望能為各位讀者在采用MySQL數據庫開發.NET應用的時候提供一個有價值的參考。
標簽如何
網友評論
刮刮乐怎么做