SvAdvSchedule.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. using Oracle.ManagedDataAccess.Client;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Web;
  6. namespace ReportWeb.Models
  7. {
  8. public class SvAdvSchedule
  9. {
  10. // service scheduler
  11. public int id { get; set; }
  12. public DateTime? from_date { get; set; }
  13. public DateTime? to_date { get; set; }
  14. public string schedule_name { get; set; }
  15. public int status { get; set; }
  16. public List<SvAdv> list_adv { get; set; }
  17. public static List<SvAdvSchedule> Parse(OracleDataReader reader)
  18. {
  19. List<SvAdvSchedule> result = new List<SvAdvSchedule>();
  20. List<int> listId = new List<int>();
  21. try
  22. {
  23. while (reader.Read())
  24. {
  25. SvAdvSchedule sv = new SvAdvSchedule();
  26. SvAdv adv = new SvAdv();
  27. for (int i = 0; i < reader.FieldCount; i++)
  28. {
  29. if (reader.GetName(i).ToUpper() == "ID")
  30. try
  31. {
  32. sv.id = int.Parse(reader.GetValue(i).ToString());
  33. }
  34. catch { }
  35. else if (reader.GetName(i).ToUpper() == "SCHEDULE_NAME")
  36. try
  37. {
  38. sv.schedule_name = reader.GetValue(i).ToString();
  39. }
  40. catch { }
  41. else if (reader.GetName(i).ToUpper() == "FROM_DATE")
  42. try
  43. {
  44. sv.from_date = reader.GetDateTime(i);
  45. }
  46. catch { }
  47. else if (reader.GetName(i).ToUpper() == "TO_DATE")
  48. try
  49. {
  50. sv.to_date = reader.GetDateTime(i);
  51. }
  52. catch { }
  53. else if (reader.GetName(i).ToUpper() == "STATUS")
  54. try
  55. {
  56. sv.status = int.Parse(reader.GetValue(i).ToString());
  57. }
  58. catch { }
  59. // adv info
  60. else if (reader.GetName(i).ToUpper() == "SV_ADV_ID")
  61. {
  62. try
  63. {
  64. adv.id = int.Parse(reader.GetValue(i).ToString());
  65. }
  66. catch { }
  67. }
  68. else if (reader.GetName(i).ToUpper() == "SV_CODE")
  69. {
  70. try
  71. {
  72. adv.sv_code = reader.GetValue(i).ToString();
  73. }
  74. catch { }
  75. }
  76. else if (reader.GetName(i).ToUpper() == "MSG_ADV")
  77. try
  78. {
  79. adv.msg_adv = reader.GetValue(i).ToString();
  80. }
  81. catch { }
  82. else if (reader.GetName(i).ToUpper() == "ADV_NAME")
  83. try
  84. {
  85. adv.adv_name = reader.GetValue(i).ToString();
  86. }
  87. catch { }
  88. else if (reader.GetName(i).ToUpper() == "MESSAGE_TYPE")
  89. try
  90. {
  91. adv.message_type = reader.GetValue(i).ToString();
  92. }
  93. catch { }
  94. else if (reader.GetName(i).ToUpper() == "CHANNEL_ADV")
  95. try
  96. {
  97. adv.channel_adv = reader.GetValue(i).ToString();
  98. }
  99. catch { }
  100. else if (reader.GetName(i).ToUpper() == "FROM_MONEY")
  101. try
  102. {
  103. adv.from_money = reader.GetValue(i).ToString();
  104. }
  105. catch { }
  106. else if (reader.GetName(i).ToUpper() == "PERCENT")
  107. try
  108. {
  109. adv.percent = int.Parse(reader.GetValue(i).ToString());
  110. }
  111. catch { }
  112. }
  113. if (listId.Contains(sv.id))
  114. {
  115. // add to list
  116. for (int i = 0; i < result.Count; i++)
  117. {
  118. SvAdvSchedule s = result[i];
  119. if (s.id == sv.id)
  120. {
  121. result[i].list_adv.Add(adv);
  122. break;
  123. }
  124. }
  125. }
  126. else
  127. {
  128. listId.Add(sv.id);
  129. // new list
  130. List<SvAdv> listTemp = new List<SvAdv>();
  131. listTemp.Add(adv);
  132. sv.list_adv = listTemp;
  133. result.Add(sv);
  134. }
  135. }
  136. reader.Close();
  137. }
  138. catch
  139. {
  140. }
  141. finally
  142. {
  143. try
  144. {
  145. reader.Close();
  146. }
  147. catch { }
  148. }
  149. return result;
  150. }
  151. }
  152. }