如何在.NET中使用MySQL数据库

数据库 MySQL 后端
本文作者与大家分享了在.NET平台使用MySQL数据库的经验,在.NET平台中使用MySQL数据库需要下载一个MySQL驱动包,并将组件引入的VS中,然后编写一个控制台程序。

在.NET中一直使用Sql Server做数据库。前几天学习通过JDBC使用Java连接MySql数据库,我就想.NET是否同样可以使用MySql数据库呢?答案是肯定的,方法也很简单,在这里我使用C#作为编程语言,将自己整理出来的方法同大家一起分享。

欲在.NET中使用MySql数据库,其步骤是:

1. 下载MySql驱动包
2. 引用驱动包中已经编译好的MySql类组件
3. 编写代码

步骤一:下载MySql驱动包

在我写篇文章的时候,***的驱动包是5.2,支持Visual Studio 2008。官方下载地址是http://dev.mysql.com/downloads/connector/net/5.2.html

步骤二:引入组件

下载的文件是一个压缩文件,将其解压缩到本地磁盘。找到bin文件夹中的MySql.Data.dll文件,这个就是我们要引用的组件。通过Visual Studio将其引用到你的项目中

步骤三:编码,我编写了一个控制台的示例,并将重要的部分都添加了注释,代码如下:

1[[228]][[229]]/**
 2[[230]] * 程序名称:使用.NET连接MySql数据库
 3[[230]] * 作者:吴磊
 4[[230]] * 日期:2009年01月17日
 5[[231]] */

 6[[232]]
 7[[232]]// 使用MySql.Data.MySqlClient命名空间
 8[[232]]using System;
 9[[232]]using MySql.Data.MySqlClient;
10[[232]]
11[[232]]namespace Project_Personnel.db
12[[228]][[229]]{
13[[230]]    class dbManage
14[[234]][[235]]    {
15[[234]][[235]]        /// 
16[[230]]        /// 连接到MySql数据库并返回连接对象
17[[230]]        /// 

18[[236]]        /// 数据库连接对象

19[[230]]        private static MySqlConnection getCon()
20[[234]][[235]]        {
21[[230]]            MySqlConnection myCon = null;
22[[230]]            try
23[[234]][[235]]            {
24[[234]][[235]]                /*
25[[230]]                 * Server:数据库服务器。localhost表示本机
26[[230]]                 * Database:数据库名称。school表示mySql中一个名为school的数据库
27[[230]]                 * Uid:用户名
28[[230]]                 * Pwd:密码
29[[230]]                 * CharSet:使用的字符编码。不设置可能产生乱码
30[[236]]                 */

31[[230]]                myCon = new MySqlConnection("Server=localhost;Database=school;
Uid=root;Pwd=123;CharSet=utf8;
");
32[[230]]                myCon.Open();
33[[236]]            }

34[[230]]            catch (MySqlException e)
35[[234]][[235]]            {
36[[230]]                //抛出连接MySql数据库的异常
37[[230]]                throw new Exception(e.Message);
38[[236]]            }

39[[230]]            return myCon;
40[[236]]        }

41[[230]]
42[[230]]        public static void Main()
43[[234]][[235]]        {
44[[230]]            try
45[[234]][[235]]            {
46[[230]]                //从shool表中检索数据的sql语句(别误会,我是在school数据库中建立了一个school表)
47[[230]]                MySqlCommand myCmd = new MySqlCommand("select * from school", getCon());
48[[230]]               
49[[230]]                //执行检索语句并将执行结果赋值给MySqlDataReader对象
50[[230]]                MySqlDataReader myReader = myCmd.ExecuteReader();
51[[230]]
52[[230]]                //进行读取
53[[230]]                while (myReader.Read())
54[[234]][[235]]                {
55[[230]]                    //myReader的FieldCount属性表示列数
56[[230]]                    for (int i = 0; i < myReader.FieldCount; i++)
57[[234]][[235]]                    {
58[[234]][[235]]                        /*
59[[230]]                         * 提示:如果使用此if语句,会产生异常:数据为空,不能对空值调用此方法或属性。
60[[230]]                         * 判断索引为i的列中的值是否为空,如果为空输出NULL
61[[236]]                         */

62[[230]]                        if (!myReader[i].Equals(DBNull.Value))
63[[234]][[235]]                        {
64[[230]]                            Console.Write("{0,10}", myReader[i]);
65[[236]]                        }

66[[230]]                        else
67[[234]][[235]]                        {
68[[230]]                            Console.Write("{0,10}""Null");
69[[236]]                        }

70[[236]]                    }

71[[230]]                    //换行
72[[230]]                    Console.WriteLine();
73[[236]]                }

74[[236]]            }

75[[230]]            //捕获MySql异常
76[[230]]            catch (MySqlException e)
77[[234]][[235]]            {
78[[230]]                Console.WriteLine(e.Message);
79[[236]]            }

80[[230]]            //捕获其他异常
81[[230]]            catch (Exception e)
82[[234]][[235]]            {
83[[230]]                Console.WriteLine(e.Message);
84[[236]]            }

85[[230]]            finally
86[[234]][[235]]            {
87[[230]]                Console.ReadKey();
88[[236]]            }

89[[236]]        }

90[[236]]    }

91[[231]]}

【编辑推荐】

  1. 专题:MySQL数据库入门与精通教程
  2. 使用Ja.Net实现Java和.NET的完美互用
  3. 平台之争 Java与.NET谁更有前途
责任编辑:佚名 来源: 吴磊的博客
相关推荐

2021-03-09 07:27:40

Kafka开源分布式

2011-01-20 10:39:09

postfixmysql

2024-01-30 15:29:20

Django数据库Python

2021-09-10 10:30:22

Java代码

2023-12-01 09:18:27

AxiosAxios 库

2009-10-26 12:47:38

VB.NET使用ORA

2009-03-30 10:34:03

ASP.NETMySQL

2022-12-08 08:00:00

.NET 7BitArray数据执行

2021-03-17 09:45:31

LazyCacheWindows

2021-02-02 16:19:08

Serilog日志框架

2021-02-06 21:40:13

SignalR通讯TypeScript

2021-02-28 20:56:37

NCache缓存框架

2021-03-10 09:40:43

LamarASP容器

2021-02-03 13:35:25

ASPweb程序

2021-01-28 22:39:35

LoggerMessa开源框架

2021-01-07 07:39:07

工具接口 Swagger

2021-03-03 22:37:16

MediatR中介者模式

2021-01-31 22:56:50

FromServiceASP

2021-02-07 17:29:04

监视文件接口

2019-08-19 14:06:27

MySQLDocker数据库
点赞
收藏

51CTO技术栈公众号