跳转到路径导航栏
跳转到正文内容

在.NET中访问MySQL数据库

http://www.sina.com.cn  2008年12月10日 02:26  《程序员》

  如果你不是只在大集团公司工作过的话,你一定会有机会接触到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();

  }

上一页 1 2 下一页

>话题讨论查看全部评论

已有 _COUNT_位网友发表评论  
登录名: 密码: 匿名发表

Powered By Google 感动2008,留下你最想说的话!
flash

新浪简介About Sina广告服务联系我们招聘信息网站律师SINA English会员注册产品答疑┊Copyright © 1996-2008 SINA Corporation, All Rights Reserved

新浪公司 版权所有