好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

关于C#连接Mysql

缘起 由于一些特别的原因,我再次短暂的回到 Windows ,回到了 VisualStudio2010 和 C# 。习惯了 Ubuntu/Linux 的快速高效的开发环境,对 Windows 下的开发工具的庞大臃肿反应慢既愤慨又无奈。由于不想使用和 VisaulStudio2010 相同的臃肿的开发环境,就使用

缘起

由于一些特别的原因,我再次短暂的回到 Windows ,回到了 Visual Studio 2010 和 C# 。习惯了 Ubuntu/Linux 的快速高效的开发环境,对 Windows 下的开发工具的庞大臃肿反应慢既愤慨又无奈。由于不想使用和 Visaul Studio 2010 相同的臃肿的开发环境,就使用 C#+Mysql 这个组合。以下是一些记录。

正文

连接数据库最重要是找到驱动程序, ODBC 、JDBC是数据库连接的接口的标准,实现这些接口称为驱动程序。无论什么语言何种平台,都需要连接数据库都需要相应的驱动器。比如连接 Mysql 数据库, Java 就需要 Java 的连接器, .NET 就需要 .NET 的连接器,像 Ruby 这类的脚本程序也需要相应的数据库连接包。

关于在 Windows 下用 C# 开发应用程序,如果是 ASP.NET+C# 的话,没的选,只有 Visual Studio ;如果开发 C# 的 WinForm 程序或控制台程序, IDE 可以选择 SharpDevelop 或者 MonoDevelop , SharpDevelop 的启动速度很快,几乎秒开,但 SharpDevelop 只适用 Windows ; MonoDevelop 可以跨平台,可以在 Windows 或 Linux 下使用。

1. C# 连接 Mysql

关于 C# 连接数据库方法是使用 Mysql 官方的提供的 connector-net的包,然后将其引用到项目中,这个方式可以适用与任何使用 C# 开发的程序,包括 Visual Studio 和 MonoDevelop 创建的项目。具体的操作步骤如下 :

1. 下载 connector

Mysql 的 connector -net 下载地址 : http://dev.mysql.com/downloads/connector/net/

2014 年 5 月份,最新的连接版本是 :6.8.3 ,该包中含有的文件 :


其中, Vx.0 表示的是 .NETFramework 的版本号,根据项目使用的 .NETFramework选择相应的目录下的 Mysql.**.dll 。

2. 在项目中 引用 mysql-connector-net 包中的 MySql.Data.dll (注意引用和项目使用框架相同的版本 dll )

3. 设置 数据库连接字符串

字符串的样例如下 :

Server=localhost;user id=root;password=localhost;Database=web;Port=3306;charset=utf8;

一般而言,这里需要修改的只有password和 database ,其他的都可以使用默认。

4.简单测试数据库连接的demo程序

using System;
using System.Collections.Generic;
using MySql.Data.MySqlClient;//引用Mysql.data.dll中的类
 
namespace testdb
{
    class Program
    {
        static void Main(string[] args)
        {
            string query = "select * from t_user";
            MySqlConnection myConnection = new MySqlConnection("server=localhost;user id=root;password=11;database=db_user");
            MySqlCommand myCommand = new MySqlCommand(query, myConnection);
            myConnection.Open();
            myCommand.ExecuteNonQuery();
            MySqlDataReader myDataReader = myCommand.ExecuteReader();
            string bookres = "";
            while (myDataReader.Read() == true)
            {
                bookres += myDataReader["id"];
                bookres += myDataReader["userName"];
                bookres += myDataReader["password"];
            }
            myDataReader.Close();
            myConnection.Close();
            Console.WriteLine(bookres); 
        }
    }
} 

2. MySQLHelper辅助类

像上面的测试连接的样例中那样,每次都自己编写相应的连接之类的非常不方便,此时,可以考虑使用一个 DBhelper 这样的辅助类来减少重复代码。下面是一个简单的 Dbheper 辅助类:

public class MySQLHelper
{
    private static string connectionString = ConfigurationManager.ConnectionStrings["mysqlconn"].ConnectionString;
    ///  
    /// 执行查询语句,返回DataSet
    ///  
    /// 查询语句
    ///  DataSet 
    public static DataSet Query(string SQLString)
    {
        using (MySqlConnection connection = new MySqlConnection(connectionString))
        {
            DataSet ds = new DataSet();
            try
            {
                connection.Open();
                MySqlDataAdapter command = new MySqlDataAdapter(SQLString, connection);
                command.Fill(ds);
            }
            catch (System.Data.SqlClient.SqlException ex)
            {
                throw new Exception(ex.Message);
            }
            finally
            {
                connection.Close();
            }
            return ds;
        }
    }
    ///  
    /// 执行SQL语句,返回影响的记录数
    ///  
    /// SQL语句
    ///  影响的记录数 
    public static int ExecuteSql(string SQLString)
    {
        using (MySqlConnection connection = new MySqlConnection(connectionString))
        {
            using (MySqlCommand cmd = new MySqlCommand(SQLString, connection))
            {
                try
                {
                    connection.Open();
                    int rows = cmd.ExecuteNonQuery();
                    return rows;
                }
                catch (System.Data.SqlClient.SqlException e)
                {
                    connection.Close();
                    throw e;
                }
                finally
                {
                    cmd.Dispose();
                    connection.Close();
                }
            }
        }
    }
    ///  
    /// 执行SQL语句,返回影响的记录数
    ///  
    /// SQL语句
    ///  影响的记录数 
    public static int ExecuteSql(string[] arrSql)
    {
        using (MySqlConnection connection = new MySqlConnection(connectionString))
        {
 
            try
            {
                connection.Open();
                MySqlCommand cmdEncoding = new MySqlCommand(SET_ENCODING, connection);
                cmdEncoding.ExecuteNonQuery();
                int rows = 0;
                foreach (string strN in arrSql)
                {
                    using (MySqlCommand cmd = new MySqlCommand(strN, connection))
                    {
                        rows += cmd.ExecuteNonQuery();
                    }
                }
                return rows;
            }
            catch (System.Data.SqlClient.SqlException e)
            {
                connection.Close();
                throw e;
            }
            finally
            {
                connection.Close();
            }
        }
    }
} 

备注: SQLserver 代码改写成 mysql 很容易 , 由于二者格式几乎一样,而改写的部分也很少。

后记

再次回到 Windows 修改C# 的 WinForm 程序,让我反思了一些问题,比如 Rails 到底能做到什么,桌面程序和 web 程序优缺点这类的问题 ,也算不错。不过,再次明白 windows 确实不是一个好的开发环境。

回想起来,自己当初在选择技术时,选择的是 C# ,为此花费了一年的时间来学习 C# 。后来,跟老师搞研究,转战 Java ,最后,在拥抱 ubuntu 一年后,选择了 Rails 和 Ruby 作为谋生的工具。这次,再次回到短暂的 windows 上,让我想到当初花了很长的时间学习,也应该积累了很多的经验,可惜的是都没有记下来,然后,就全忘光了。

参考文献

1. .net mysql-connector-net 连接 mysql

2. asp.net 连接 Mysql(connector/net 5.0)

查看更多关于关于C#连接Mysql的详细内容...

  阅读:42次