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.

119 line
4.6KB

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using MySql.Data.MySqlClient;
  5. namespace CSVDownloader.Store.CreditCSVData {
  6. class CreditCSVDataDaito : CreditCSVData {
  7. public String parking_name = "";
  8. public String developer = "";
  9. public String adjust_type = "";
  10. public String fee_type = "";
  11. public DateTime reception_datetime = DateTime.Now;
  12. public int amount = 0;
  13. public String reception_no = "";
  14. public String response_no = "";
  15. public String error_code1 = "";
  16. public String error_code2 = "";
  17. public enum ColName {
  18. SpotID = 100,
  19. ParkingName = 0,
  20. Developer,
  21. AdjustType,
  22. FeeType,
  23. ReceptionDatetime,
  24. Amount,
  25. ReceptionNo,
  26. ResponseNo,
  27. ErrorCode1,
  28. ErrorCode2,
  29. UpdDate,
  30. UpdStaff,
  31. RegDate,
  32. RegStaff
  33. };
  34. }
  35. class DaitoCreitDataStore : CreditCSVDataStore {
  36. private static readonly String table_name_ = "creditcard_download_data_daito";
  37. private String delete_sql_ = $"delete from {table_name_} where " +
  38. $"{CreditCSVDataDaito.ColName.ReceptionDatetime.ToString()} between " +
  39. $"@From{CreditCSVDataDaito.ColName.ReceptionDatetime.ToString()} and " +
  40. $"@To{CreditCSVDataDaito.ColName.ReceptionDatetime.ToString()};";
  41. public DaitoCreitDataStore(MySqlConnection conn) : base(conn) {
  42. }
  43. public override void Save(List<CreditCSVData> list) {
  44. Code.ResultCode ret;
  45. var table = new DataTable();
  46. table.Columns.Add($"{CreditCSVDataDaito.ColName.SpotID}");
  47. table.Columns.Add($"{CreditCSVDataDaito.ColName.ParkingName}");
  48. table.Columns.Add($"{CreditCSVDataDaito.ColName.Developer}");
  49. table.Columns.Add($"{CreditCSVDataDaito.ColName.AdjustType}");
  50. table.Columns.Add($"{CreditCSVDataDaito.ColName.FeeType}");
  51. table.Columns.Add($"{CreditCSVDataDaito.ColName.ReceptionDatetime}");
  52. table.Columns.Add($"{CreditCSVDataDaito.ColName.Amount}");
  53. table.Columns.Add($"{CreditCSVDataDaito.ColName.ReceptionNo}");
  54. table.Columns.Add($"{CreditCSVDataDaito.ColName.ResponseNo}");
  55. table.Columns.Add($"{CreditCSVDataDaito.ColName.ErrorCode1}");
  56. table.Columns.Add($"{CreditCSVDataDaito.ColName.ErrorCode2}");
  57. table.Columns.Add($"{CreditCSVDataDaito.ColName.UpdStaff}");
  58. table.Columns.Add($"{CreditCSVDataDaito.ColName.RegStaff}");
  59. foreach (CreditCSVDataDaito data in list) {
  60. var row = table.NewRow();
  61. row[$"{CreditCSVDataDaito.ColName.SpotID}"] = data.spot_id;
  62. row[$"{CreditCSVDataDaito.ColName.ParkingName}"] = data.parking_name;
  63. row[$"{CreditCSVDataDaito.ColName.Developer}"] = data.developer;
  64. row[$"{CreditCSVDataDaito.ColName.AdjustType}"] = data.adjust_type;
  65. row[$"{CreditCSVDataDaito.ColName.FeeType}"] = data.fee_type;
  66. row[$"{CreditCSVDataDaito.ColName.ReceptionDatetime}"] = data.reception_datetime;
  67. row[$"{CreditCSVDataDaito.ColName.Amount}"] = data.amount;
  68. row[$"{CreditCSVDataDaito.ColName.ReceptionNo}"] = data.reception_no;
  69. row[$"{CreditCSVDataDaito.ColName.ResponseNo}"] = data.response_no;
  70. row[$"{CreditCSVDataDaito.ColName.ErrorCode1}"] = data.error_code1;
  71. row[$"{CreditCSVDataDaito.ColName.ErrorCode2}"] = data.error_code2;
  72. row[$"{CreditCSVDataDaito.ColName.UpdStaff}"] = data.upd_staff;
  73. row[$"{CreditCSVDataDaito.ColName.RegStaff}"] = data.reg_staff;
  74. table.Rows.Add(row);
  75. }
  76. ret = BulkInsertData(table_name_, table);
  77. if (ret != Code.ResultCode.OK) {
  78. throw new Exception("登録失敗 Daito");
  79. }
  80. }
  81. public override int Delete(DateTime from, DateTime to) {
  82. var bindlist = new List<(String, object)> {
  83. ("From"+CreditCSVDataDaito.ColName.ReceptionDatetime.ToString(), from.ToString("yyyy-MM-dd")),
  84. ("To"+CreditCSVDataDaito.ColName.ReceptionDatetime.ToString(), to.AddDays(1).ToString("yyyy-MM-dd"))
  85. };
  86. var delete_count = DeleteData(delete_sql_, bindlist);
  87. if (delete_count == -1) {
  88. throw new Exception("削除失敗 大都");
  89. }
  90. return delete_count;
  91. }
  92. }
  93. }