当前位置:Gxlcms > mysql > 关于C#连接Mysql

关于C#连接Mysql

时间:2021-07-01 10:21:17 帮助过:28人阅读

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

缘起

由于一些特别的原因,我再次短暂的回到Windows,回到了Visual Studio 2010C#。习惯了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或者MonoDevelopSharpDevelop的启动速度很快,几乎秒开,但SharpDevelop只适用WindowsMonoDevelop可以跨平台,可以在WindowsLinux下使用。

1. C#连接Mysql

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

1.下载connector

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

20145月份,最新的连接版本是: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程序

  1. using System;
  2. using System.Collections.Generic;
  3. using MySql.Data.MySqlClient;//引用Mysql.data.dll中的类
  4. namespace testdb
  5. {
  6. class Program
  7. {
  8. static void Main(string[] args)
  9. {
  10. string query = "select * from t_user";
  11. MySqlConnection myConnection = new MySqlConnection("server=localhost;user id=root;password=11;database=db_user");
  12. MySqlCommand myCommand = new MySqlCommand(query, myConnection);
  13. myConnection.Open();
  14. myCommand.ExecuteNonQuery();
  15. MySqlDataReader myDataReader = myCommand.ExecuteReader();
  16. string bookres = "";
  17. while (myDataReader.Read() == true)
  18. {
  19. bookres += myDataReader["id"];
  20. bookres += myDataReader["userName"];
  21. bookres += myDataReader["password"];
  22. }
  23. myDataReader.Close();
  24. myConnection.Close();
  25. Console.WriteLine(bookres);
  26. }
  27. }
  28. }

2. MySQLHelper辅助类

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

  1. public class MySQLHelper
  2. {
  3. private static string connectionString = ConfigurationManager.ConnectionStrings["mysqlconn"].ConnectionString;
  4. /// <summary>
  5. /// 执行查询语句,返回DataSet
  6. /// </summary>
  7. /// <param name="SQLString">查询语句
  8. /// <returns>DataSet</returns>
  9. public static DataSet Query(string SQLString)
  10. {
  11. using (MySqlConnection connection = new MySqlConnection(connectionString))
  12. {
  13. DataSet ds = new DataSet();
  14. try
  15. {
  16. connection.Open();
  17. MySqlDataAdapter command = new MySqlDataAdapter(SQLString, connection);
  18. command.Fill(ds);
  19. }
  20. catch (System.Data.SqlClient.SqlException ex)
  21. {
  22. throw new Exception(ex.Message);
  23. }
  24. finally
  25. {
  26. connection.Close();
  27. }
  28. return ds;
  29. }
  30. }
  31. /// <summary>
  32. /// 执行SQL语句,返回影响的记录数
  33. /// </summary>
  34. /// <param name="SQLString">SQL语句
  35. /// <returns>影响的记录数</returns>
  36. public static int ExecuteSql(string SQLString)
  37. {
  38. using (MySqlConnection connection = new MySqlConnection(connectionString))
  39. {
  40. using (MySqlCommand cmd = new MySqlCommand(SQLString, connection))
  41. {
  42. try
  43. {
  44. connection.Open();
  45. int rows = cmd.ExecuteNonQuery();
  46. return rows;
  47. }
  48. catch (System.Data.SqlClient.SqlException e)
  49. {
  50. connection.Close();
  51. throw e;
  52. }
  53. finally
  54. {
  55. cmd.Dispose();
  56. connection.Close();
  57. }
  58. }
  59. }
  60. }
  61. /// <summary>
  62. /// 执行SQL语句,返回影响的记录数
  63. /// </summary>
  64. /// <param name="SQLString">SQL语句
  65. /// <returns>影响的记录数</returns>
  66. public static int ExecuteSql(string[] arrSql)
  67. {
  68. using (MySqlConnection connection = new MySqlConnection(connectionString))
  69. {
  70. try
  71. {
  72. connection.Open();
  73. MySqlCommand cmdEncoding = new MySqlCommand(SET_ENCODING, connection);
  74. cmdEncoding.ExecuteNonQuery();
  75. int rows = 0;
  76. foreach (string strN in arrSql)
  77. {
  78. using (MySqlCommand cmd = new MySqlCommand(strN, connection))
  79. {
  80. rows += cmd.ExecuteNonQuery();
  81. }
  82. }
  83. return rows;
  84. }
  85. catch (System.Data.SqlClient.SqlException e)
  86. {
  87. connection.Close();
  88. throw e;
  89. }
  90. finally
  91. {
  92. connection.Close();
  93. }
  94. }
  95. }
  96. }

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

后记

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

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

参考文献

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

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

人气教程排行