Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

66 lines
1.9KB

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using MySql.Data.MySqlClient;
  5. namespace CSVDownloader.Store {
  6. class MySqlConnectionParameter {
  7. public String host;
  8. public int port;
  9. public String database;
  10. public String user;
  11. public String password;
  12. }
  13. class MySQL {
  14. private log4net.ILog logger_ = log4net.LogManager.GetLogger("");
  15. protected MySqlConnection conn_;
  16. public MySQL(MySqlConnection conn) {
  17. conn_ = conn;
  18. }
  19. public static MySqlConnection GetConnection(MySqlConnectionParameter param) {
  20. String conn_string = $"Server={param.host}; Port={param.port}; Database={param.database}; Uid={param.user}; Pwd={param.password}";
  21. var conn = new MySqlConnection(conn_string);
  22. conn.Open();
  23. return conn;
  24. }
  25. private int ExecuteNonQuery(String sql, List<(String, object)> bindlist) {
  26. // logger_.Debug($"{sql}");
  27. int ret = 0;
  28. using (var cmd = conn_.CreateCommand()) {
  29. cmd.CommandText = sql;
  30. foreach (var ele in bindlist) {
  31. // logger_.Debug($"bind @{ele.Item1} = {ele.Item2}");
  32. cmd.Parameters.AddWithValue($"@{ele.Item1}", ele.Item2);
  33. }
  34. cmd.Prepare();
  35. ret = cmd.ExecuteNonQuery();
  36. }
  37. return ret;
  38. }
  39. protected Code.ResultCode InsertData(String sql, List<(String, object)> bindlist) {
  40. var ret = ExecuteNonQuery(sql, bindlist);
  41. if (ret == -1) {
  42. return Code.ResultCode.NG;
  43. }
  44. return Code.ResultCode.OK;
  45. }
  46. protected int DeleteData(String sql, List<(String, object)> bindlist) {
  47. return ExecuteNonQuery(sql, bindlist);
  48. }
  49. }
  50. }