You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

104 lines
2.9KB

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Text;
  5. using MySql.Data.MySqlClient;
  6. namespace CSVDownloader.Store {
  7. class MySqlConnectionParameter {
  8. public String host;
  9. public int port;
  10. public String database;
  11. public String user;
  12. public String password;
  13. }
  14. class MySQL {
  15. private log4net.ILog logger_ = log4net.LogManager.GetLogger("");
  16. protected MySqlConnection conn_;
  17. public MySQL(MySqlConnection conn) {
  18. conn_ = conn;
  19. }
  20. public static MySqlConnection GetConnection(MySqlConnectionParameter param) {
  21. String conn_string = $"Server={param.host}; Port={param.port}; Database={param.database}; Uid={param.user}; Pwd={param.password}; Charset='utf8'";
  22. var conn = new MySqlConnection(conn_string);
  23. conn.Open();
  24. return conn;
  25. }
  26. private int ExecuteNonQuery(String sql, List<(String, object)> bindlist) {
  27. // logger_.Debug($"{sql}");
  28. int ret = 0;
  29. using (var cmd = conn_.CreateCommand()) {
  30. cmd.CommandText = sql;
  31. foreach (var ele in bindlist) {
  32. // logger_.Debug($"bind @{ele.Item1} = {ele.Item2}");
  33. cmd.Parameters.AddWithValue($"@{ele.Item1}", ele.Item2);
  34. }
  35. cmd.Prepare();
  36. ret = cmd.ExecuteNonQuery();
  37. }
  38. return ret;
  39. }
  40. protected Code.ResultCode BulkInsertData(String tablename, DataTable table) {
  41. // SQL のビルド
  42. var sql = new StringBuilder();
  43. var bind_list = new List<(String, object)>();
  44. sql.Append($"insert into {tablename} (");
  45. for (int i = 0; i < table.Columns.Count; i++) {
  46. if (i != 0) {
  47. sql.Append(",");
  48. }
  49. sql.Append($"{table.Columns[i]}");
  50. }
  51. sql.Append($") values ");
  52. for (int row = 0; row < table.Rows.Count; row++) {
  53. if (row != 0) {
  54. sql.Append(",");
  55. }
  56. sql.Append("(");
  57. for (int col = 0; col < table.Columns.Count; col++) {
  58. if (col != 0) {
  59. sql.Append(",");
  60. }
  61. String key = $"@{table.Columns[col]}{row}";
  62. sql.Append(key);
  63. bind_list.Add((key, table.Rows[row][table.Columns[col]]));
  64. }
  65. sql.Append(")");
  66. }
  67. // 値のセット
  68. var ret = ExecuteNonQuery(sql.ToString(), bind_list);
  69. if (ret == -1) {
  70. return Code.ResultCode.NG;
  71. }
  72. return Code.ResultCode.OK;
  73. }
  74. protected int DeleteData(String sql, List<(String, object)> bindlist) {
  75. return ExecuteNonQuery(sql, bindlist);
  76. }
  77. }
  78. }