如何在.NET中使用MySQL数据库
创始人
2024-03-20 17:31:13
0

在.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]][[233]]{
13[[230]]    class dbManage
14[[234]][[235]]    [[233]]{
15[[234]][[235]]        /**//// 
16[[230]]        /// 连接到MySql数据库并返回连接对象
17[[230]]        /// 

18[[236]]        /// 数据库连接对象
19[[230]]        private static MySqlConnection getCon()
20[[234]][[235]]        [[233]]{
21[[230]]            MySqlConnection myCon = null;
22[[230]]            try
23[[234]][[235]]            [[233]]{
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]]            [[233]]{
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]]        [[233]]{
44[[230]]            try
45[[234]][[235]]            [[233]]{
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]]                [[233]]{
55[[230]]                    //myReader的FieldCount属性表示列数
56[[230]]                    for (int i = 0; i < myReader.FieldCount; i++)
57[[234]][[235]]                    [[233]]{
58[[234]][[235]]                        /**//*
59[[230]]                         * 提示:如果使用此if语句,会产生异常:数据为空,不能对空值调用此方法或属性。
60[[230]]                         * 判断索引为i的列中的值是否为空,如果为空输出NULL
61[[236]]                         */
62[[230]]                        if (!myReader[i].Equals(DBNull.Value))
63[[234]][[235]]                        [[233]]{
64[[230]]                            Console.Write("{0,10}", myReader[i]);
65[[236]]                        }
66[[230]]                        else
67[[234]][[235]]                        [[233]]{
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]]            [[233]]{
78[[230]]                Console.WriteLine(e.Message);
79[[236]]            }
80[[230]]            //捕获其他异常
81[[230]]            catch (Exception e)
82[[234]][[235]]            [[233]]{
83[[230]]                Console.WriteLine(e.Message);
84[[236]]            }
85[[230]]            finally
86[[234]][[235]]            [[233]]{
87[[230]]                Console.ReadKey();
88[[236]]            }
89[[236]]        }
90[[236]]    }
91[[231]]}

【编辑推荐】

  1. 专题:MySQL数据库入门与精通教程
  2. 使用Ja.Net实现Java和.NET的完美互用
  3. 平台之争 Java与.NET谁更有前途

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...