OracleHelper.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  1. using Common;
  2. using Npgsql;
  3. using Oracle.ManagedDataAccess.Client;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Configuration;
  7. using System.Data;
  8. using System.Reflection;
  9. namespace LisPacsDataUpload
  10. {
  11. public class OracleHelper<T> where T : class
  12. {
  13. //数据库连接变量
  14. //private static OracleConnection conn = null;
  15. //数据库事务变量
  16. //private static OracleTransaction transaction = null;
  17. //连接字符串
  18. public static string GetConnStr()
  19. {
  20. return ConfigurationManager.ConnectionStrings["conn"].ConnectionString;
  21. }
  22. //连接字符串
  23. public static string GetPgConnStr()
  24. {
  25. return ConfigurationManager.ConnectionStrings["pgConn"].ConnectionString;
  26. }
  27. /// <summary>
  28. /// 轮询间隔时间
  29. /// </summary>
  30. /// <returns></returns>
  31. public static int Time()
  32. {
  33. return Convert.ToInt32(ConfigurationManager.AppSettings["time"]) * 60 * 1000;
  34. }
  35. /// <summary>
  36. /// 数据上传开始时间
  37. /// </summary>
  38. /// <returns></returns>
  39. public static int StartTime()
  40. {
  41. return Convert.ToInt32(ConfigurationManager.AppSettings["start_time"]);
  42. }
  43. public static int UploadPacs()
  44. {
  45. return Convert.ToInt32(ConfigurationManager.AppSettings["pacs"]);
  46. }
  47. public static int UploadLis()
  48. {
  49. return Convert.ToInt32(ConfigurationManager.AppSettings["lis"]);
  50. }
  51. public static int UploadTime()
  52. {
  53. return Convert.ToInt32(ConfigurationManager.AppSettings["upload_time"]);
  54. }
  55. //public static OracleConnection getConnection()
  56. //{
  57. // OracleConnection conn = null;
  58. // if (conn == null || conn.State == ConnectionState.Closed)
  59. // openConnection();
  60. // return conn;
  61. //}
  62. private static object openLock = new object();
  63. //打开数据库连接
  64. private static bool openConnection(OracleConnection conn)
  65. {
  66. lock (openLock)
  67. {
  68. try
  69. {
  70. conn = new OracleConnection(GetConnStr());
  71. conn.Close();
  72. if (conn.State != ConnectionState.Open)
  73. {
  74. conn.Open();
  75. return true;
  76. }
  77. }
  78. catch (Exception ex)
  79. {
  80. LogHelper.Info("打开数据库出错," + ex.Message);
  81. }
  82. finally { }
  83. return false;
  84. }
  85. //lock (openLock)
  86. //{
  87. // try
  88. // {
  89. // //打开连接
  90. // if (conn == null || conn.State == ConnectionState.Closed)
  91. // {
  92. // conn = new OracleConnection(GetConnStr());
  93. // conn.Open();
  94. // }
  95. // }
  96. // catch (Exception ex)
  97. // {
  98. // LogHelper.Error(ex, ex.Message);
  99. // //throw new Exception(ex.Message, ex);
  100. // }
  101. }
  102. private static object closeLock = new object();
  103. //关闭数据库连接
  104. private static void closeConnection()
  105. {
  106. lock (closeLock)
  107. {
  108. OracleConnection conn = null;
  109. if (conn != null)
  110. {
  111. if (conn.State == ConnectionState.Open)
  112. conn.Close();
  113. }
  114. }
  115. //lock(closeLock)
  116. //{
  117. // try
  118. // {
  119. // if (conn != null)
  120. // {
  121. // if (conn.State == ConnectionState.Open)
  122. // conn.Close();
  123. // }
  124. // }
  125. // catch (Exception ex)
  126. // {
  127. // LogHelper.Error(ex, ex.Message);
  128. // //throw new Exception(ex.Message, ex);
  129. // }
  130. //}
  131. }
  132. private static object DSLock = new object();
  133. /// <summary>
  134. /// 查询,返回DataSet
  135. /// </summary>
  136. /// <param name="sql"></param>
  137. /// <returns></returns>
  138. public static DataTable RunQueryDS(string sql)
  139. {
  140. //lock (DSLock)
  141. //{
  142. DataTable dt = new DataTable();
  143. using (OracleConnection conn = new OracleConnection(GetConnStr()))
  144. {
  145. try
  146. {
  147. conn.Open();
  148. OracleDataAdapter oda = new OracleDataAdapter(sql, conn);
  149. //DataSet ds = new DataSet();
  150. oda.Fill(dt);
  151. //dt = ds.Tables[0];
  152. }
  153. catch (Exception ex)
  154. {
  155. LogHelper.Info("查询出错sql:" + sql);
  156. LogHelper.Error(ex, ex.Message);
  157. //throw new Exception(ex.Message);
  158. }
  159. finally
  160. {
  161. //closeConnection();
  162. conn.Close();
  163. }
  164. }
  165. return dt;
  166. //}
  167. }
  168. /// <summary>
  169. /// 查询,返回DataSet
  170. /// </summary>
  171. /// <param name="sql"></param>
  172. /// <returns></returns>
  173. public static DataTable PgQueryDS(string sql)
  174. {
  175. DataTable dataTable = new DataTable();
  176. using (NpgsqlConnection connection = new NpgsqlConnection(GetPgConnStr()))
  177. {
  178. connection.Open();
  179. using (NpgsqlCommand command = new NpgsqlCommand(sql, connection))
  180. {
  181. using (NpgsqlDataReader reader = command.ExecuteReader())
  182. {
  183. dataTable.Load(reader);
  184. }
  185. }
  186. }
  187. return dataTable;
  188. }
  189. /// <summary>
  190. /// 执行存储过程
  191. /// </summary>
  192. /// <param name="procName">存储过程名</param>
  193. /// <param name="commandParameters">参数列表</param>
  194. public static void ExecuteProcedure(string procName, params OracleParameter[] commandParameters)
  195. {
  196. //initConnection();
  197. //initTransaction();
  198. try
  199. {
  200. OracleConnection conn = null;
  201. //执行命令
  202. OracleCommand cmd = new OracleCommand();
  203. cmd.Connection = conn;
  204. cmd.CommandText = procName;
  205. cmd.CommandType = CommandType.StoredProcedure;
  206. // 绑定传入的参数
  207. if (commandParameters != null)
  208. {
  209. foreach (OracleParameter parm in commandParameters)
  210. {
  211. cmd.Parameters.Add(parm);
  212. }
  213. }
  214. cmd.ExecuteNonQuery();
  215. //commitTransaction();
  216. cmd.Parameters.Clear();
  217. }
  218. catch (Exception ex)
  219. {
  220. //rollbackTransaction();
  221. LogHelper.Error(ex, ex.Message);
  222. throw new Exception(ex.Message, ex);
  223. }
  224. finally
  225. {
  226. //关闭数据库连接
  227. closeConnection();
  228. }
  229. }
  230. private static object ExtObjectLock = new object();
  231. /// <summary>
  232. /// 执行一个update,insert,delete,drop等SQL
  233. /// </summary>
  234. /// <param name="cmdText">SQL值</param>
  235. /// <returns>执行是否成功</returns>
  236. public static int ExecuteNonQuery(string sql)
  237. {
  238. //lock (ExtObjectLock)
  239. //{
  240. int val = 0;
  241. //initTransaction();
  242. OracleTransaction tran = null;
  243. using (OracleConnection conn = new OracleConnection(GetConnStr()))
  244. {
  245. //创建连接
  246. try
  247. {
  248. conn.Open();
  249. if (conn.State != ConnectionState.Connecting)
  250. {
  251. bool isb = false;
  252. try
  253. {
  254. tran = conn.BeginTransaction();
  255. isb = true;
  256. }
  257. catch
  258. { }
  259. finally
  260. {
  261. if (isb)
  262. {
  263. //创建一个新的命令
  264. OracleCommand cmd = new OracleCommand();
  265. cmd.CommandType = CommandType.Text;
  266. cmd.Connection = conn;
  267. cmd.Transaction = tran;
  268. //cmd.Connection = tran.Connection;
  269. cmd.CommandText = sql;
  270. //执行命令
  271. val = cmd.ExecuteNonQuery();
  272. tran.Commit();
  273. }
  274. }
  275. }
  276. }
  277. catch (System.Exception ex)
  278. {
  279. val = 0;
  280. //rollbackTransaction();
  281. LogHelper.Info("执行出错sql:" + sql);
  282. LogHelper.Error(ex, ex.Message);
  283. if (tran != null) { tran.Rollback(); tran.Dispose(); tran = null; }
  284. }
  285. finally
  286. {
  287. tran.Dispose();
  288. //关闭数据库连接
  289. //closeConnection();
  290. conn.Close();
  291. }
  292. }
  293. return val;
  294. //}
  295. }
  296. public static int PgExecuteNonQuery(string query)
  297. {
  298. int newId=1;
  299. try {
  300. using (var conn = new NpgsqlConnection(GetPgConnStr()))
  301. {
  302. using (var command = new NpgsqlCommand(query, conn))
  303. {
  304. conn.Open();
  305. command.ExecuteScalar();
  306. }
  307. }
  308. }
  309. catch (Exception e) {
  310. LogHelper.Info(e.Message + e.InnerException);
  311. return 0;
  312. }
  313. //, params object[] parameters 这是入参 暂时不用
  314. return newId;
  315. }
  316. /// <summary>
  317. /// 将DataSet转换为泛型集合List
  318. /// </summary>
  319. /// <param name="ds">要转换的DataSet数据集</param>
  320. /// <returns>转换之后的泛型集合</returns>
  321. private static List<T> DataSetToList(DataSet ds)
  322. {
  323. List<T> list = new List<T>();
  324. try
  325. {
  326. // 根据数据量进行遍历
  327. for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
  328. {
  329. // 通过类型创建该类型的实例
  330. T _t = (T)Activator.CreateInstance(typeof(T));
  331. // 通过创建的实例获取该实例下的所有公共字段
  332. PropertyInfo[] propertys = _t.GetType().GetProperties();
  333. // 使用嵌套循环遍历数据列,匹配数据列名称与获取的公共字段名称,对符合的字段进行赋值
  334. foreach (PropertyInfo pi in propertys)
  335. {
  336. for (int j = 0; j < ds.Tables[0].Columns.Count; j++)
  337. {
  338. if (pi.Name.Equals(ds.Tables[0].Columns[j].ColumnName))
  339. {
  340. //LogHelper.Info("666:" + ds.Tables[0].Columns[j].ColumnName);
  341. if (ds.Tables[0].Rows[i][j] != DBNull.Value)
  342. pi.SetValue(_t, ds.Tables[0].Rows[i][j], null);
  343. else
  344. // 对于数据库中的Null值需要进行单独处理
  345. pi.SetValue(_t, "", null);
  346. }
  347. }
  348. }
  349. list.Add(_t);
  350. }
  351. }
  352. catch (Exception ex)
  353. {
  354. // 抛出异常,上层进行异常捕获和处理并记录错误日志
  355. throw new Exception(ex.Message);
  356. }
  357. return list;
  358. }
  359. private static object ListLock = new object();
  360. /// <summary>
  361. /// 查询操作(返回泛型集合)当有查询操作时,应优先考虑使用RunQueryList方法
  362. /// </summary>
  363. /// <param name="sql">要执行的查询语句</param>
  364. /// <returns>对应数据实体的泛型集合</returns>
  365. public static List<T> RunQueryList(string sql)
  366. {
  367. //lock (ListLock)
  368. //{
  369. List<T> list = new List<T>();
  370. using (OracleConnection conn = new OracleConnection(GetConnStr()))
  371. {
  372. try
  373. {
  374. conn.Open();
  375. DataSet ds = new DataSet();
  376. OracleDataAdapter oda = new OracleDataAdapter(sql, conn);
  377. oda.Fill(ds);
  378. // 若没有查询到任何数据,则返回空
  379. if (ds == null || ds.Tables.Count < 0)
  380. return null;
  381. // 调用DataSet转List的转换方法
  382. list = DataSetToList(ds);
  383. }
  384. catch (Exception ex)
  385. {
  386. //conn.Close();
  387. LogHelper.Error(ex, ex.Message);
  388. LogHelper.Info("查询出错sql:" + sql);
  389. //throw new Exception(ex.Message);
  390. }
  391. finally
  392. {
  393. conn.Close();
  394. //closeConnection();
  395. }
  396. }
  397. return list;
  398. //}
  399. }
  400. public static List<T> PgRunQueryList(string sql)
  401. {
  402. List<T> ts = new List<T>();
  403. try
  404. {
  405. using (var conn = new NpgsqlConnection(GetPgConnStr()))
  406. {
  407. if (conn.State != ConnectionState.Open)
  408. {
  409. conn.Open();
  410. }
  411. T t = default(T);
  412. using (var nda = new NpgsqlDataAdapter(sql, conn))
  413. {
  414. DataTable dt = new DataTable();
  415. nda.Fill(dt);
  416. // 获得此模型的类型
  417. // Type type = typeof(McDevice);
  418. string tempName = "";
  419. foreach (DataRow dr in dt.Rows)
  420. {
  421. t = Activator.CreateInstance<T>();
  422. // 获得此模型的公共属性
  423. PropertyInfo[] propertys = t.GetType().GetProperties();
  424. foreach (PropertyInfo pi in propertys)
  425. {
  426. tempName = pi.Name; // 检查DataTable是否包含此列
  427. if (dt.Columns.Contains(tempName))
  428. {
  429. // 判断此属性是否有Setter
  430. if (!pi.CanWrite) continue;
  431. object value = dr[tempName];
  432. if (value != DBNull.Value)
  433. pi.SetValue(t, value, null);
  434. }
  435. }
  436. ts.Add(t);
  437. }
  438. }
  439. }
  440. }
  441. catch (Exception ex) { LogHelper.Info("查询pg数据返回lis集合异常" + ex.Message); }
  442. return ts;
  443. }
  444. }
  445. }