SoftSqlOperate.cs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Data.SqlClient;
  6. using System.Data;
  7. namespace HslCommunication.BasicFramework
  8. {
  9. //=================================================================================================
  10. //
  11. // 创建时间:2017年09月03日 20:56:18
  12. // 有关数据库操作的方法,进行总结精简,提供了三个非常常用的方法方便调用
  13. //
  14. //=================================================================================================
  15. /// <summary>
  16. /// 数据库操作的相关类,包含了常用的方法,避免大量的重复代码
  17. /// </summary>
  18. public static class SoftSqlOperate
  19. {
  20. /// <summary>
  21. /// 普通的执行SQL语句,并返回影响行数,该方法应该放到try-catch代码块中
  22. /// </summary>
  23. /// <param name="conStr">数据库的连接字符串</param>
  24. /// <param name="cmdStr">sql语句,适合插入,更新,删除</param>
  25. /// <returns>返回受影响的行数</returns>
  26. /// <exception cref="SqlException"></exception>
  27. public static int ExecuteSql(string conStr, string cmdStr)
  28. {
  29. using (SqlConnection conn = new SqlConnection(conStr))
  30. {
  31. conn.Open();
  32. return ExecuteSql(conn, cmdStr);
  33. }
  34. }
  35. /// <summary>
  36. /// 普通的执行SQL语句,并返回影响行数,该方法应该放到try-catch代码块中
  37. /// </summary>
  38. /// <param name="conn">数据库的连接对象</param>
  39. /// <param name="cmdStr">sql语句,适合插入,更新,删除</param>
  40. /// <returns>返回受影响的行数</returns>
  41. /// <exception cref="SqlException"></exception>
  42. public static int ExecuteSql(SqlConnection conn, string cmdStr)
  43. {
  44. using (SqlCommand cmd = new SqlCommand(cmdStr, conn))
  45. {
  46. return cmd.ExecuteNonQuery();
  47. }
  48. }
  49. /// <summary>
  50. /// 选择数据表的执行SQL语句,并返回最终数据表,该方法应该放到try-catch代码块中
  51. /// </summary>
  52. /// <param name="conStr">数据库的连接字符串</param>
  53. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  54. /// <returns>结果数据表</returns>
  55. /// <exception cref="SqlException"></exception>
  56. /// <exception cref="InvalidOperationException"></exception>
  57. public static DataTable ExecuteSelectTable(string conStr, string cmdStr)
  58. {
  59. using (SqlConnection conn = new SqlConnection(conStr))
  60. {
  61. conn.Open();
  62. return ExecuteSelectTable(conn, cmdStr);
  63. }
  64. }
  65. /// <summary>
  66. /// 选择数据表的执行SQL语句,并返回最终数据表,该方法应该放到try-catch代码块中
  67. /// </summary>
  68. /// <param name="conn">数据库连接对象</param>
  69. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  70. /// <returns>结果数据表</returns>
  71. /// <exception cref="SqlException"></exception>
  72. public static DataTable ExecuteSelectTable(SqlConnection conn, string cmdStr)
  73. {
  74. using (SqlDataAdapter sda = new SqlDataAdapter(cmdStr, conn))
  75. {
  76. using (DataSet ds = new DataSet())
  77. {
  78. sda.Fill(ds);
  79. return ds.Tables[0];
  80. }
  81. }
  82. }
  83. /// <summary>
  84. /// 选择指定类型数据集合执行SQL语句,并返回指定类型的数据集合,该方法应该放到try-catch代码块中
  85. /// </summary>
  86. /// <param name="conStr">数据库的连接字符串</param>
  87. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  88. /// <returns>结果数据集合</returns>
  89. /// <exception cref="SqlException"></exception>
  90. /// <exception cref="InvalidOperationException"></exception>
  91. public static List<T> ExecuteSelectEnumerable<T>(string conStr, string cmdStr) where T : ISqlDataType, new()
  92. {
  93. using (SqlConnection conn = new SqlConnection(conStr))
  94. {
  95. conn.Open();
  96. return ExecuteSelectEnumerable<T>(conn, cmdStr);
  97. }
  98. }
  99. /// <summary>
  100. /// 选择指定类型数据集合执行SQL语句,并返回指定类型的数据集合,该方法应该放到try-catch代码块中
  101. /// </summary>
  102. /// <param name="conn">数据库的连接对象</param>
  103. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  104. /// <returns>结果数据集合</returns>
  105. /// <exception cref="SqlException"></exception>
  106. /// <exception cref="InvalidOperationException"></exception>
  107. public static List<T> ExecuteSelectEnumerable<T>(SqlConnection conn, string cmdStr) where T : ISqlDataType, new()
  108. {
  109. using (SqlCommand cmd = new SqlCommand(cmdStr, conn))
  110. {
  111. using (SqlDataReader sdr = cmd.ExecuteReader())
  112. {
  113. List<T> list = new List<T>();
  114. while (sdr.Read())
  115. {
  116. T item = new T();
  117. item.LoadBySqlDataReader(sdr);
  118. list.Add(item);
  119. }
  120. return list;
  121. }
  122. }
  123. }
  124. /// <summary>
  125. /// 更新指定类型数据执行SQL语句,并返回指定类型的数据集合,该方法应该放到try-catch代码块中
  126. /// </summary>
  127. /// <param name="conStr">数据库的连接字符串</param>
  128. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  129. /// <returns>结果数据</returns>
  130. /// <exception cref="SqlException"></exception>
  131. /// <exception cref="InvalidOperationException"></exception>
  132. public static T ExecuteSelectObject<T>(string conStr, string cmdStr) where T : ISqlDataType, new()
  133. {
  134. using (SqlConnection conn = new SqlConnection(conStr))
  135. {
  136. conn.Open();
  137. return ExecuteSelectObject<T>(conn, cmdStr);
  138. }
  139. }
  140. /// <summary>
  141. /// 更新指定类型数据执行SQL语句,并返回指定类型的数据集合,该方法应该放到try-catch代码块中
  142. /// </summary>
  143. /// <param name="conn">数据库的连接对象</param>
  144. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  145. /// <returns>结果数据</returns>
  146. /// <exception cref="SqlException"></exception>
  147. /// <exception cref="InvalidOperationException"></exception>
  148. public static T ExecuteSelectObject<T>(SqlConnection conn, string cmdStr) where T : ISqlDataType, new()
  149. {
  150. using (SqlCommand cmd = new SqlCommand(cmdStr, conn))
  151. {
  152. using (SqlDataReader sdr = cmd.ExecuteReader())
  153. {
  154. if (sdr.Read())
  155. {
  156. T item = new T();
  157. item.LoadBySqlDataReader(sdr);
  158. return item;
  159. }
  160. else
  161. {
  162. return default(T);
  163. }
  164. }
  165. }
  166. }
  167. /// <summary>
  168. /// 用于选择聚合函数值的方法,例如Count,Average,Max,Min,Sum等最终只有一个结果值的对象
  169. /// </summary>
  170. /// <param name="conStr">数据库的连接字符串</param>
  171. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  172. /// <returns></returns>
  173. public static int ExecuteSelectCount(string conStr, string cmdStr)
  174. {
  175. using (SqlConnection conn = new SqlConnection(conStr))
  176. {
  177. conn.Open();
  178. return ExecuteSelectCount(conn, cmdStr);
  179. }
  180. }
  181. /// <summary>
  182. /// 用于选择聚合函数值的方法,例如Count,Average,Max,Min,Sum等最终只有一个结果值的对象
  183. /// </summary>
  184. /// <param name="conn">数据库的连接对象</param>
  185. /// <param name="cmdStr">sql语句,选择数据表的语句</param>
  186. /// <returns></returns>
  187. public static int ExecuteSelectCount(SqlConnection conn, string cmdStr)
  188. {
  189. using (SqlCommand cmd = new SqlCommand(cmdStr, conn))
  190. {
  191. int temp = 0;
  192. SqlDataReader sdr = cmd.ExecuteReader();
  193. if (sdr.Read())
  194. {
  195. temp = Convert.ToInt32(sdr[0]);
  196. }
  197. sdr.Close();
  198. return temp;
  199. }
  200. }
  201. }
  202. /// <summary>
  203. /// 数据库对应类的读取接口
  204. /// </summary>
  205. public interface ISqlDataType
  206. {
  207. /// <summary>
  208. /// 根据sdr对象初始化数据的方法
  209. /// </summary>
  210. /// <param name="sdr"></param>
  211. void LoadBySqlDataReader(SqlDataReader sdr);
  212. }
  213. }