MySQL 以其免費和足夠的性能受到很大的青睞,當然對于國內小公司,甚至是大公司如果對版權看得薄,敢冒險的話,隨便裝個 SqlServer、DB2、Oracle 都行。對于 SqlServer 數據庫,因其與 MS 是一家,自然在 .net 類庫中有內建支持,假如 MySQL 就得找第三方的驅動了 -- .net 中多講 Provider。在這里我也是作為一個預研專題,記錄下 C# 連接 MySQL 的兩種方法,分別使用 MySQL 官方的和 SourceForge 上一個開源的 MySQL 驅動。至于 ODBC 的辦法,就不提了,覺得意義不大,同樣要安裝個 MySQL ODBC 驅動,而且 ODBC 又如此之笨拙。
使用 MySQL 官方區動連接操作 MySQL 數據庫
下載驅動,可在 http://www.mysql.com/downloads/connector/net/6.3.html#downloads 下載,當前版本是 6.3。你可以選擇的平臺既可以是 Microsoft Windows,也可以用 .Net & Mono 的,區別是 Microsoft Windows 的是一個MSI 文件,后者是非安裝的壓縮包。但是那個 MSI 文件在我的 64 位 XP 下安裝不成功,所以用了后者。
這個 connector net 不光是個 MySQL 驅動,還提供了像 Entity Frameword、Asp.Net Web Providers、Compact Framework、VS 2008 集成的支持,還配置 CSharp 和 VB 的例子。詳細的配置、使用文檔請參考安裝目錄中的 MySql.Data.chm 文件。
現在從最簡單的例子開始,驅動安裝完,或壓縮包解開后,甭里安裝目錄里的 mysql.data.cf.dll、mysql.data.entiry.dll、mysql.visualstudio.dll 和 mysql.web.dll,我們暫時在項目中引入 mysql.data.dll,用 using MySql.Data.MySqlClient; 引入命名空間。然后簡單的代碼如下:
我想,在做正式的應用時,為防止 SQL 注入時關于參數化查詢肯定會被提出來的,那就來看看這個 MySQL 官方驅動如何處理參數化查詢的。它所用的方式和 SqlServer Provider 是一樣的,用 @author 這樣的形式來標識參數,并且同樣支持 AddWithValue(string name, object value) 的方式。請看代碼:
對于 InnoDB 存儲引擎的 MySQL 是支持事物的,這個官方的的驅動支持事物的代碼如下:
[code]
MySqlTransaction trans = con.BeginTransaction(); //啟用事物
trans.Commit(); //正常時提交
trans.Rollback(); //異常時回滾
[code]
下一篇將介紹如何使用 SourceForge 上的開源 MySQL .Net 驅動怎么去操作 MySQL 數據庫的。
新聞熱點
疑難解答