ConnectDB.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. using Oracle.ManagedDataAccess.Client;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Security.Cryptography;
  6. namespace UAS_Tools_HY.PublicMethods
  7. {
  8. internal class ConnectDB
  9. {
  10. private static readonly string ConnectionString = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=10.1.81.208)(PORT=11687))(CONNECT_DATA=(SERVICE_NAME=orcl)));User Id=N_MES_HY;Password=select!#%*(;";
  11. public static bool TestConnection()
  12. {
  13. try
  14. {
  15. using (OracleConnection connection = new OracleConnection(ConnectionString))
  16. {
  17. connection.Open();
  18. return true;
  19. }
  20. }
  21. catch (Exception ex)
  22. {
  23. throw new Exception($"数据库连接测试失败: {ex.Message}");
  24. }
  25. }
  26. public static DataTable ExecuteSelect(string sqlQuery, Dictionary<string, object> parameters = null)
  27. {
  28. DataTable dataTable = new DataTable();
  29. try
  30. {
  31. using (OracleConnection connection = new OracleConnection(ConnectionString))
  32. {
  33. connection.Open();
  34. using (OracleCommand command = new OracleCommand(sqlQuery, connection))
  35. {
  36. if (parameters != null && parameters.Count > 0)
  37. {
  38. foreach (var param in parameters)
  39. {
  40. command.Parameters.Add(new OracleParameter(param.Key, param.Value ?? DBNull.Value));
  41. }
  42. }
  43. using (OracleDataAdapter adapter = new OracleDataAdapter(command))
  44. {
  45. adapter.Fill(dataTable);
  46. }
  47. }
  48. }
  49. }
  50. catch (Exception ex)
  51. {
  52. throw new Exception(ex.Message);
  53. }
  54. return dataTable;
  55. }
  56. public static int ExecuteInsert(string sqlQuery, Dictionary<string, object> parameters = null)
  57. {
  58. try
  59. {
  60. using (OracleConnection connection = new OracleConnection(ConnectionString))
  61. {
  62. connection.Open();
  63. using (OracleCommand command = new OracleCommand(sqlQuery, connection))
  64. {
  65. if (parameters != null && parameters.Count > 0)
  66. {
  67. foreach (var param in parameters)
  68. {
  69. command.Parameters.Add(new OracleParameter(param.Key, param.Value ?? DBNull.Value));
  70. }
  71. }
  72. return command.ExecuteNonQuery();
  73. }
  74. }
  75. }
  76. catch (Exception ex)
  77. {
  78. throw new Exception(ex.Message);
  79. }
  80. }
  81. public static int ExecuteUpdate(string sqlQuery, Dictionary<string, object> parameters = null)
  82. {
  83. try
  84. {
  85. using (OracleConnection connection = new OracleConnection(ConnectionString))
  86. {
  87. connection.Open();
  88. using (OracleCommand command = new OracleCommand(sqlQuery, connection))
  89. {
  90. if (parameters != null && parameters.Count > 0)
  91. {
  92. foreach (var param in parameters)
  93. {
  94. command.Parameters.Add(new OracleParameter(param.Key, param.Value ?? DBNull.Value));
  95. }
  96. }
  97. return command.ExecuteNonQuery();
  98. }
  99. }
  100. }
  101. catch (Exception ex)
  102. {
  103. throw new Exception(ex.Message);
  104. }
  105. }
  106. public static int ExecuteDelete(string sqlQuery, Dictionary<string, object> parameters = null)
  107. {
  108. try
  109. {
  110. using (OracleConnection connection = new OracleConnection(ConnectionString))
  111. {
  112. connection.Open();
  113. using (OracleCommand command = new OracleCommand(sqlQuery, connection))
  114. {
  115. if (parameters != null && parameters.Count > 0)
  116. {
  117. foreach (var param in parameters)
  118. {
  119. command.Parameters.Add(new OracleParameter(param.Key, param.Value ?? DBNull.Value));
  120. }
  121. }
  122. return command.ExecuteNonQuery();
  123. }
  124. }
  125. }
  126. catch (Exception ex)
  127. {
  128. throw new Exception(ex.Message);
  129. }
  130. }
  131. }
  132. }