MySqlTools.cs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. using MySql.Data.MySqlClient;
  2. using System;
  3. using System.Data;
  4. namespace X2D1NoRefTaskServer
  5. {
  6. public static class MySqlTools
  7. {
  8. /// <summary>
  9. /// 用现有的数据库连接执行一个sql命令(不返回数据集)
  10. /// </summary>
  11. /// <param name="cmdType">命令类型(存储过程, 文本, 等等)</param>
  12. /// <param name="cmdText">存储过程名称或者sql命令语句</param>
  13. /// <param name="commandParameters">执行命令所用参数的集合</param>
  14. /// <returns>执行命令所影响的行数</returns>
  15. public static int ExecuteNonQuery(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  16. {
  17. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  18. using (MySqlConnection conn = new MySqlConnection(connectionString))
  19. {
  20. MySqlCommand cmd = new MySqlCommand();
  21. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  22. int val = cmd.ExecuteNonQuery();
  23. cmd.Parameters.Clear();
  24. return val;
  25. }
  26. }
  27. /// <summary>
  28. /// 用执行的数据库连接执行一个返回数据集的sql命令
  29. /// </summary>
  30. /// <remarks>
  31. /// 举例:
  32. /// MySqlDataReader r = ExecuteReader(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
  33. /// </remarks>
  34. /// <param name="cmdType">命令类型(存储过程, 文本, 等等)</param>
  35. /// <param name="cmdText">存储过程名称或者sql命令语句</param>
  36. /// <param name="commandParameters">执行命令所用参数的集合</param>
  37. /// <returns>包含结果的读取器</returns>
  38. public static MySqlDataReader ExecuteReader(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  39. {
  40. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  41. using (MySqlConnection conn = new MySqlConnection(connectionString))
  42. {
  43. MySqlCommand cmd = new MySqlCommand();
  44. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  45. MySqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
  46. cmd.Parameters.Clear();
  47. return reader;
  48. }
  49. }
  50. /// <summary>
  51. /// 返回DataSet
  52. /// </summary>
  53. /// <param name="cmdType">命令类型(存储过程, 文本, 等等)</param>
  54. /// <param name="cmdText">存储过程名称或者sql命令语句</param>
  55. /// <param name="commandParameters">执行命令所用参数的集合</param>
  56. /// <returns></returns>
  57. public static DataSet GetDataSet(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  58. {
  59. MySqlCommand cmd = new MySqlCommand();
  60. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  61. using (MySqlConnection conn = new MySqlConnection(connectionString))
  62. {
  63. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  64. MySqlDataAdapter adapter = new MySqlDataAdapter();
  65. adapter.SelectCommand = cmd;
  66. DataSet ds = new DataSet();
  67. adapter.Fill(ds);
  68. cmd.Parameters.Clear();
  69. conn.Close();
  70. return ds;
  71. }
  72. }
  73. /// <summary>
  74. /// 用指定的数据库连接字符串执行一个命令并返回一个数据表
  75. /// </summary>
  76. /// <param name="cmdType">命令类型(存储过程, 文本, 等等)</param>
  77. /// <param name="cmdText">存储过程名称或者sql命令语句</param>
  78. /// <param name="commandParameters">执行命令所用参数的集合</param>
  79. public static DataTable GetDataTable(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  80. {
  81. MySqlCommand cmd = new MySqlCommand();
  82. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  83. using (MySqlConnection conn = new MySqlConnection(connectionString))
  84. {
  85. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  86. MySqlDataAdapter adapter = new MySqlDataAdapter();
  87. adapter.SelectCommand = cmd;
  88. DataTable ds = new DataTable();
  89. adapter.Fill(ds);
  90. cmd.Parameters.Clear();
  91. conn.Close();
  92. return ds;
  93. }
  94. }
  95. /// <summary>
  96. /// 用指定的数据库连接字符串执行一个命令并返回一个数据集的第一列
  97. /// </summary>
  98. /// <remarks>
  99. ///例如:
  100. /// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
  101. /// </remarks>
  102. /// <param name="cmdType">命令类型(存储过程, 文本, 等等)</param>
  103. /// <param name="cmdText">存储过程名称或者sql命令语句</param>
  104. /// <param name="commandParameters">执行命令所用参数的集合</param>
  105. /// <returns>用 Convert.To{Type}把类型转换为想要的 </returns>
  106. public static object ExecuteScalar(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  107. {
  108. MySqlCommand cmd = new MySqlCommand();
  109. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  110. using (MySqlConnection conn = new MySqlConnection(connectionString))
  111. {
  112. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  113. object val = cmd.ExecuteScalar();
  114. cmd.Parameters.Clear();
  115. return val;
  116. }
  117. }
  118. /// <summary>
  119. /// 返回插入值ID
  120. /// </summary>
  121. /// <param name="cmdType"></param>
  122. /// <param name="cmdText"></param>
  123. /// <param name="commandParameters"></param>
  124. /// <returns></returns>
  125. public static object ExecuteNonExist(CommandType cmdType, string cmdText, params MySqlParameter[] commandParameters)
  126. {
  127. MySqlCommand cmd = new MySqlCommand();
  128. string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["MySql"].ConnectionString;
  129. using (MySqlConnection connection = new MySqlConnection(connectionString))
  130. {
  131. PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);
  132. object val = cmd.ExecuteNonQuery();
  133. return cmd.LastInsertedId;
  134. }
  135. }
  136. /// <summary>
  137. /// 准备执行一个命令
  138. /// </summary>
  139. /// <param name="cmd">sql命令</param>
  140. /// <param name="conn">OleDb连接</param>
  141. /// <param name="trans">OleDb事务</param>
  142. /// <param name="cmdType">命令类型例如 存储过程或者文本</param>
  143. /// <param name="cmdText">命令文本,例如:Select * from Products</param>
  144. /// <param name="cmdParms">执行命令的参数</param>
  145. private static void PrepareCommand(MySqlCommand cmd, MySqlConnection conn, MySqlTransaction trans, CommandType cmdType, string cmdText, MySqlParameter[] cmdParms)
  146. {
  147. if (conn.State != ConnectionState.Open)
  148. conn.Open();
  149. cmd.Connection = conn;
  150. cmd.CommandText = cmdText;
  151. if (trans != null)
  152. cmd.Transaction = trans;
  153. cmd.CommandType = cmdType;
  154. if (cmdParms != null)
  155. {
  156. foreach (MySqlParameter parm in cmdParms)
  157. cmd.Parameters.Add(parm);
  158. }
  159. }
  160. }
  161. }