时间:2021-02-18 11:20:46 | 栏目:.NET代码 | 点击:次
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 数据库的。