洛阳中航光电项目,为12年项目,此处使用反编译工具恢复源码,恢复为.netframe4.0版本,但仍需使用ie8访问; 数据库使用oracle,现再192.168.8.3服务器,访问账户scott,密码800100

SqlHelper.cs 8.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. using System;
  2. using System.Collections;
  3. using System.Configuration;
  4. using System.Data;
  5. using System.Data.SqlClient;
  6. namespace DBUtility
  7. {
  8. public abstract class SqlHelper
  9. {
  10. public static readonly string ConnectionStringLocalTransaction = ConfigurationManager.AppSettings["strCoon"].ToString();
  11. public static readonly string ConnectionStringInventoryDistributedTransaction = "";
  12. public static readonly string ConnectionStringOrderDistributedTransaction = "";
  13. public static readonly string ConnectionStringProfile = "";
  14. public static readonly string ConnectionStringMembership = "";
  15. private static Hashtable parmCache = Hashtable.Synchronized(new Hashtable());
  16. public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  17. {
  18. SqlCommand cmd = new SqlCommand();
  19. int result;
  20. using (SqlConnection conn = new SqlConnection(connectionString))
  21. {
  22. SqlHelper.PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  23. int val = cmd.ExecuteNonQuery();
  24. cmd.Parameters.Clear();
  25. conn.Close();
  26. conn.Dispose();
  27. result = val;
  28. }
  29. return result;
  30. }
  31. public static int ExecuteNonQuery(SqlConnection connection, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  32. {
  33. SqlCommand cmd = new SqlCommand();
  34. SqlHelper.PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);
  35. int val = cmd.ExecuteNonQuery();
  36. cmd.Parameters.Clear();
  37. connection.Close();
  38. connection.Dispose();
  39. return val;
  40. }
  41. public static int ExecuteNonQuery(SqlTransaction trans, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  42. {
  43. SqlCommand cmd = new SqlCommand();
  44. SqlHelper.PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, commandParameters);
  45. int val = cmd.ExecuteNonQuery();
  46. cmd.Parameters.Clear();
  47. return val;
  48. }
  49. public static SqlDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  50. {
  51. SqlCommand cmd = new SqlCommand();
  52. SqlConnection conn = new SqlConnection(connectionString);
  53. SqlDataReader result;
  54. try
  55. {
  56. SqlHelper.PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  57. SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
  58. cmd.Parameters.Clear();
  59. result = rdr;
  60. }
  61. catch
  62. {
  63. conn.Close();
  64. conn.Dispose();
  65. throw;
  66. }
  67. return result;
  68. }
  69. public static object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  70. {
  71. SqlCommand cmd = new SqlCommand();
  72. object result;
  73. using (SqlConnection connection = new SqlConnection(connectionString))
  74. {
  75. SqlHelper.PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);
  76. object val = cmd.ExecuteScalar();
  77. cmd.Parameters.Clear();
  78. connection.Close();
  79. connection.Dispose();
  80. result = val;
  81. }
  82. return result;
  83. }
  84. public static object ExecuteScalar(SqlConnection connection, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  85. {
  86. SqlCommand cmd = new SqlCommand();
  87. SqlHelper.PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);
  88. object val = cmd.ExecuteScalar();
  89. cmd.Parameters.Clear();
  90. return val;
  91. }
  92. public static void CacheParameters(string cacheKey, params SqlParameter[] commandParameters)
  93. {
  94. SqlHelper.parmCache[cacheKey] = commandParameters;
  95. }
  96. public static SqlParameter[] GetCachedParameters(string cacheKey)
  97. {
  98. SqlParameter[] cachedParms = (SqlParameter[])SqlHelper.parmCache[cacheKey];
  99. SqlParameter[] result;
  100. if (cachedParms == null)
  101. {
  102. result = null;
  103. }
  104. else
  105. {
  106. SqlParameter[] clonedParms = new SqlParameter[cachedParms.Length];
  107. int i = 0;
  108. int j = cachedParms.Length;
  109. while (i < j)
  110. {
  111. clonedParms[i] = (SqlParameter)((ICloneable)cachedParms[i]).Clone();
  112. i++;
  113. }
  114. result = clonedParms;
  115. }
  116. return result;
  117. }
  118. private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, CommandType cmdType, string cmdText, SqlParameter[] cmdParms)
  119. {
  120. if (conn.State != ConnectionState.Open)
  121. {
  122. conn.Open();
  123. }
  124. cmd.Connection = conn;
  125. cmd.CommandText = cmdText;
  126. cmd.CommandTimeout = 300;
  127. if (trans != null)
  128. {
  129. cmd.Transaction = trans;
  130. }
  131. cmd.CommandType = cmdType;
  132. if (cmdParms != null)
  133. {
  134. for (int i = 0; i < cmdParms.Length; i++)
  135. {
  136. SqlParameter parm = cmdParms[i];
  137. if (parm.Value == null)
  138. {
  139. parm.Value = DBNull.Value;
  140. }
  141. cmd.Parameters.Add(parm);
  142. }
  143. }
  144. }
  145. public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText)
  146. {
  147. return SqlHelper.ExecuteDataset(connectionString, commandType, commandText, null);
  148. }
  149. public static DataSet ExecuteDataset(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  150. {
  151. DataSet result;
  152. using (SqlConnection cn = new SqlConnection(connectionString))
  153. {
  154. cn.Open();
  155. DataSet ds = SqlHelper.ExecuteDataset(cn, commandType, commandText, commandParameters);
  156. cn.Close();
  157. cn.Dispose();
  158. result = ds;
  159. }
  160. return result;
  161. }
  162. public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText)
  163. {
  164. return SqlHelper.ExecuteDataset(connection, commandType, commandText, null);
  165. }
  166. public static DataSet ExecuteDataset(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  167. {
  168. SqlCommand cmd = new SqlCommand();
  169. SqlHelper.PrepareCommand(cmd, connection, null, commandType, commandText, commandParameters);
  170. SqlDataAdapter da = new SqlDataAdapter(cmd);
  171. DataSet ds = new DataSet();
  172. da.Fill(ds);
  173. cmd.Parameters.Clear();
  174. connection.Close();
  175. connection.Dispose();
  176. return ds;
  177. }
  178. public static DataSet ExecuteDataset(SqlTransaction transaction, CommandType commandType, string commandText)
  179. {
  180. return SqlHelper.ExecuteDataset(transaction, commandType, commandText, null);
  181. }
  182. public static DataSet ExecuteDataset(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  183. {
  184. SqlCommand cmd = new SqlCommand();
  185. SqlHelper.PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters);
  186. SqlDataAdapter da = new SqlDataAdapter(cmd);
  187. DataSet ds = new DataSet();
  188. da.Fill(ds);
  189. cmd.Parameters.Clear();
  190. return ds;
  191. }
  192. public static DataTable ExecuteDataTable(string connectionString, CommandType commandType, string commandText)
  193. {
  194. return SqlHelper.ExecuteDataTable(connectionString, commandType, commandText, null);
  195. }
  196. public static DataTable ExecuteDataTable(string connectionString, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  197. {
  198. DataTable result;
  199. using (SqlConnection cn = new SqlConnection(connectionString))
  200. {
  201. cn.Open();
  202. DataTable dt = SqlHelper.ExecuteDataTable(cn, commandType, commandText, commandParameters);
  203. cn.Close();
  204. cn.Dispose();
  205. result = dt;
  206. }
  207. return result;
  208. }
  209. public static DataTable ExecuteDataTable(SqlConnection connection, CommandType commandType, string commandText)
  210. {
  211. return SqlHelper.ExecuteDataTable(connection, commandType, commandText, null);
  212. }
  213. public static DataTable ExecuteDataTable(SqlConnection connection, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  214. {
  215. SqlCommand cmd = new SqlCommand();
  216. SqlHelper.PrepareCommand(cmd, connection, null, commandType, commandText, commandParameters);
  217. SqlDataAdapter da = new SqlDataAdapter(cmd);
  218. DataTable dt = new DataTable();
  219. da.Fill(dt);
  220. cmd.Parameters.Clear();
  221. connection.Close();
  222. connection.Dispose();
  223. return dt;
  224. }
  225. public static DataTable ExecuteDataTable(SqlTransaction transaction, CommandType commandType, string commandText)
  226. {
  227. return SqlHelper.ExecuteDataTable(transaction, commandType, commandText, null);
  228. }
  229. public static DataTable ExecuteDataTable(SqlTransaction transaction, CommandType commandType, string commandText, params SqlParameter[] commandParameters)
  230. {
  231. SqlCommand cmd = new SqlCommand();
  232. SqlHelper.PrepareCommand(cmd, transaction.Connection, transaction, commandType, commandText, commandParameters);
  233. SqlDataAdapter da = new SqlDataAdapter(cmd);
  234. DataTable dt = new DataTable();
  235. da.Fill(dt);
  236. cmd.Parameters.Clear();
  237. return dt;
  238. }
  239. }
  240. }