iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >C#如何连接MySQL数据库
  • 929
分享到

C#如何连接MySQL数据库

c#mysqlc#连接数据库c#连接MySQL数据库 2022-05-24 17:05:17 929人浏览 独家记忆
摘要

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

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

  帮助文档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;
  }
}

4.增删查改的代码(MySqlCommand类、MySqlDataReader类)

  ExecuteReader——用于查询数据库。查询结果是返回MySqlDataReader对象,MySqlDataReader包含sql语句执行的结果,并提供一个方法从结果中阅读一行。

  ExecuteNonQuery——用于插入、更新和删除数据。

  ExecuteScalar——用于查询数据时,返回查询结果集中第一行第一列的值,即只返回一个值。

  (1) 查询

  a.查询条件固定


string sql= "select * from user";
MySqlCommand cmd = new MySqlCommand(sql,conn);
MySqlDataReader reader =cmd.ExecuteReader();//执行ExecuteReader()返回一个MySqlDataReader对象
while (reader.Read())//初始索引是-1,执行读取下一行数据,返回值是bool
{
  //Console.WriteLine(reader[0].ToString() + reader[1].ToString() + reader[2].ToString());
  //Console.WriteLine(reader.GetInt32(0)+reader.GetString(1)+reader.GetString(2));
  Console.WriteLine(reader.GetInt32("userid") + reader.GetString("username") + reader.GetString("password"));//"userid"是数据库对应的列名,推荐这种方式
}

b.查询条件不固定


//string sql = "select * from user where username='"+username+"' and password='"+password+"'"; //我们自己按照查询条件去组拼
string sql = "select * from user where username=@para1 and password=@para2";//在sql语句中定义parameter,然后再给parameter赋值
MySqlCommand cmd = new MySqlCommand(sql, conn);
cmd.Parameters.AddWithValue("para1", username);
cmd.Parameters.AddWithValue("para2", password);

MySqlDataReader reader = cmd.ExecuteReader();
if (reader.Read())//如果用户名和密码正确则能查询到一条语句,即读取下一行返回true
{
  return true;
}

c.需要查询返回一个值


string sql = "select count(*) from user";
MySqlCommand cmd = new MySqlCommand(sql, conn);
Object result=cmd.ExecuteScalar();//执行查询,并返回查询结果集中第一行的第一列。所有其他的列和行将被忽略。select语句无记录返回时,ExecuteScalar()返回NULL值
if (result != null)
{
  int count = int.Parse(result.ToString());
}

(2) 插入、删除、更改


string sql = "insert into user(username,password,reGISterdate) values('啊宽','123','"+DateTime.Now+"')";
//string sql = "delete from user where userid='9'";
//string sql = "update user set username='啊哈',password='123' where userid='8'";
MySqlCommand cmd = new MySqlCommand(sql,conn);
int result =cmd.ExecuteNonQuery();//3.执行插入、删除、更改语句。执行成功返回受影响的数据的行数,返回1可做true判断。执行失败不返回任何数据,报错,下面代码都不执行

5.事务(MySqlTransaction类)


String connetStr = "server=127.0.0.1;user=root;password=root;database=minecraftdb;";
MySqlConnection conn = new MySqlConnection(connetStr);
conn.Open();//必须打开通道之后才能开始事务
MySqlTransaction transaction = conn.BeginTransaction();//事务必须在try外面赋值不然catch里的transaction会报错:未赋值
Console.WriteLine("已经建立连接");
try
{
  string date = DateTime.Now.Year + "-" + DateTime.Now.Month + "-" + DateTime.Now.Day;
  string sql1= "insert into user(username,password,registerdate) values('啊宽','123','" + date + "')";
  MySqlCommand cmd1 = new MySqlCommand(sql1,conn);
  cmd1.ExecuteNonQuery();

  string sql2 = "insert into user(username,password,registerdate) values('啊宽','123','" + date + "')";
  MySqlCommand cmd2 = new MySqlCommand(sql2, conn);
  cmd2.ExecuteNonQuery();
}
catch (MySqlException ex)
{
  Console.WriteLine(ex.Message);
  transaction.Rollback();//事务ExecuteNonQuery()执行失败报错,username被设置unique
  conn.Close();
}
finally
{
  if (conn.State != ConnectionState.Closed)
  {
    transaction.Commit();//事务要么回滚要么提交,即Rollback()与Commit()只能执行一个
    conn.Close();
  }
}

结语:连接数据库、操作数据库,本质是利用数据库提供的动态链接库MySql.Data.dll进行操作。动态链接库中的8个类上面常用操作只用到了类1-5,类6-8 的相关操作未涉及, 大家可以去看帮助文档C:\Program Files (x86)\MySQL\Connector.NET 6.9\Documentation\ConnectorNET.chm学习

以上就是C#如何连接MySQL数据库的详细内容,更多关于C#连接MySQL的资料请关注自学编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: C#如何连接MySQL数据库

本文链接: https://www.lsjlt.com/news/9859.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C#连接MySQL数据库
    目录 一、引用MySql.Data.dll文件 二、连接、关闭数据库 三、数据库增删改查 附:完整代码 一、引用MySql.Data.dll文件 创建C#窗体应用程序,解决方案资源管理器中找到“引用”,右键,选择添加引用。 在MyS...
    99+
    2023-10-28
    c# 数据库 mysql
  • c++ 连接mysql数据库
            使用vs2019对window11中的数据库进行连接 1. 配置连接环境         首先需要把mysql中的头文件和库文件放入到c++项目工程中 打开安装MySQL的目录,在windows系统中如果是默认路径,应该和我...
    99+
    2023-09-03
    数据库
  • C# 连接 MySQL 数据库
    目录 一、需求 二、新建 C# 项目 三、MySQL数据库 四、MySqlHelper 五、测试 一、需求 C# 使用 MySQL 数据库的情况还是比较少的,大部分使用 Windows 平台一般使用 SQL Server,在两年前我...
    99+
    2023-09-02
    c# 数据库
  • mysql如何连接数据库
    本篇内容主要讲解“mysql如何连接数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql如何连接数据库”吧! mysql连...
    99+
    2023-01-31
    mysql 数据库
  • c\c++如何连接mysql数据库(超易上手)
    第一步:打开mysql安装目录,默认安装目录如下:C:\Program Files\MySQL\MySQL Server 8.0,确认lib目录和include目录是否存在。 这里推荐下载一个软件(everything),该软件能很快速的查...
    99+
    2023-09-08
    mysql 数据库
  • c#如何连接sqlserver数据库
    在C#中,你可以使用System.Data.SqlClient命名空间中的SqlConnection类来连接SQL Server数据...
    99+
    2023-09-23
    c# sqlserver数据库
  • c#如何连接oracle数据库
    在C#中连接Oracle数据库,可以使用Oracle的官方ADO.NET驱动程序来实现。下面是连接Oracle数据库的基本步骤: ...
    99+
    2024-04-22
    c# oracle
  • c#怎么连接mysql数据库
    在C#中连接MySQL数据库,可以使用MySQL Connector/Net,它是MySQL官方提供的用于.NET平台的数据库驱动程...
    99+
    2024-04-09
    c# mysql
  • Spring如何连接Mysql数据库
    这篇文章主要介绍了Spring如何连接Mysql数据库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、创建一个Maven项目二、导入坐标 在pom.xml...
    99+
    2023-06-29
  • JSP如何连接mysql数据库
    本篇内容主要讲解“JSP如何连接mysql数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JSP如何连接mysql数据库”吧! ...
    99+
    2024-04-02
  • java如何连接mysql数据库
    这篇文章主要介绍java如何连接mysql数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!java如何连接mysql数据库?1. 下载安装eclipse软件,以及准备“...
    99+
    2024-04-02
  • spark如何连接mysql数据库
    在Spark中连接MySQL数据库有两种方式: 使用JDBC连接: import org.apache.spark.sql.Sp...
    99+
    2024-05-06
    mysql spark
  • pandas如何连接mysql数据库
    Pandas提供了一个read_sql方法来连接和从MySQL数据库中读取数据。首先,您需要安装MySQL的Python驱动程序(例...
    99+
    2024-05-06
    mysql pandas
  • nodejs如何连接mysql数据库
    这篇文章主要介绍nodejs如何连接mysql数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!本篇文章给大家介绍一下使用nodejs连接mysql数据库的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大...
    99+
    2023-06-14
  • Golang如何连接MySQL数据库
    本篇内容主要讲解“Golang如何连接MySQL数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Golang如何连接MySQL数据库”吧!Go原生就支持连接...
    99+
    2024-04-02
  • sqoop如何连接mysql数据库
    要连接MySQL数据库,可以使用Sqoop提供的以下命令: 导入数据到HDFS: sqoop import --connect ...
    99+
    2024-04-22
    mysql sqoop
  • c++怎么连接mysql数据库
    要连接MySQL数据库,可以使用MySQL提供的MySQL C++ Connector或者第三方库来实现。 1、使用MySQL C+...
    99+
    2024-04-09
    c++ mysql
  • eclipse如何连接mysql数据库
    这期内容当中小编将会给大家带来有关eclipse如何连接mysql数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。eclipse如何连接mysql数据库1.进入ecl...
    99+
    2024-04-02
  • go如何连接mysql数据库
    在Go语言中连接MySQL数据库可以使用第三方库"github.com/go-sql-driver/mysql"...
    99+
    2024-04-02
  • SPSS如何连接mysql数据库
    本篇内容介绍了“SPSS如何连接mysql数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!安装MySQL ODBC驱动官方说法:MySQ...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作