网站链接: 我爱捣鼓
当前位置: 首页 > web开发  > Asp.net/C#

C#如何连接MySQL数据库字符串怎么写?

2021/3/1 21:36:10

本文章是建立在已经安装MySQL数据库的前提,默认安装在C:\Program Files (x86)\MySQL,建议在安装时选中Connector.NET 6.9的安装,里面有MySQL与C#连接的动态链接库。  帮助文档C:\Program Files (x86)\MySQL\Connector.NET 6.9\Documentation\ConnectorNET.chm是我撰写…

     本文章是建立在已经安装MySQL数据库的前提,默认安装在C:\Program Files (x86)\MySQL,建议在安装时选中Connector.NET 6.9的安装,里面有MySQL与C#连接的动态链接库。

  帮助文档C:\Program Files (x86)\MySQL\Connector.NET 6.9\Documentation\ConnectorNET.chm是我撰写此文章的主要依据。其中Users Guide下,Programming是对动态链接库8个类的介绍,Tutorial是案例代码。

  连接数据库、操作数据库,本质是利用数据库提供的动态链接库MySql.Data.dll进行操作。MySql.Data.dll提供以下8个类:

  MySqlConnection: 连接MySQL服务器数据库。    
    MySqlCommand:执行一条sql语句。
    MySqlDataReader: 包含sql语句执行的结果,并提供一个方法从结果中阅读一行。
    MySqlTransaction: 代表一个SQL事务在一个MySQL数据库。
    MySqlException: MySQL报错时返回的Exception。
    MySqlCommandBuilder: Automatically generates single-table commands used to reconcile changes made to a DataSet with the associated MySQL database.
    MySqlDataAdapter: Represents a set of data commands and a database connection that are used to fill a data set and update a MySQL database.
    MySqlHelper: Helper class that makes it easier to work with the provider.


1.添加动态链接库文件

  方法一:Visual Studio,在 项目(右键)-管理NuGet程序包(N)  然后在浏览里面搜索MySql.Data并进行安装。


  方法二:安装数据库MySQL时要选中Connector.NET 6.9的安装,将C:\Program Files (x86)\MySQL\Connector.NET 6.9\Assemblies里v4.0或v4.5中的MySql.Data.dll添加到项目的引用。v4.0和v4.5,对应Visual Studio具体项目 属性-应用程序-目标框架 里的.NET Framework的版本号。


2.建立连接(MySqlConnection类)


using MySql.Data.MySqlClient;
String connetStr = "server=127.0.0.1;port=3306;user=root;password=root; database=minecraftdb;";
// server=127.0.0.1/localhost 代表本机,端口号port默认是3306可以不写
MySqlConnection conn = new MySqlConnection(connetStr);
try
{    
      conn.Open();//打开通道,建立连接,可能出现异常,使用try catch语句
      Console.WriteLine("已经建立连接");
      //在这里使用代码对数据库进行增删查改
}
catch (MySqlException ex)
{
      Console.WriteLine(ex.Message);
}
finally
{
      conn.Close();
}

3.捕捉异常(MySqlException类)

  连接错误时MySqlConnection会返回一个MySqlException,其中包括2个变量:

  Message: A message that describes the current exception.

  Number: The MySQL error number. (0: Cannot connect to server. 1045: Invalid user name and/or password.)

catch (MySqlException ex)
{
    switch (ex.Number)
    {
        case 0:
        Console.WriteLine("Cannot connect to server.  Contact administrator");
        break;
    case 1045:
        Console.WriteLine("Invalid username/password, please try again");
        break;
    }
}



相关资讯

  • C#怎么获取文件夹里所有的图片文件?

    在实际的程序开发中,我们经常需要获取某个文件夹下的所有图片,用到了C#的DirectoryInfo、GetFiles等文件操作方法,具体实现如下://自定义一个结构public struct sFileInfo{ public string FileName; public DateTime FileCreateTime;}protected void Page_Load(…

    2021/3/4 21:48:01
  • c#实现日期时间与unix时间戳互相转换

    为什么使用时间戳?关于Unix时间戳,大概是这个意思,从1970年0时0分0秒开始到现在的秒数.使用它来获得的是一个INT值,储存在数据库里只要使用INT格式就可以了,方便数据库进行排序,搜索,而且比datetime格式更节省数据库空间。 /// <summary> /// Uni…

    2021/3/4 21:40:22