MsgPushService.cs 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. * 推送消息记录
  3. */
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Data;
  8. using MySystem.Models.Operate;
  9. using Library;
  10. using LitJson;
  11. namespace MySystem.Service.Operate
  12. {
  13. public class MsgPushService
  14. {
  15. string _conn = "";
  16. public MsgPushService()
  17. {
  18. _conn = ConfigurationManager.AppSettings["OpSqlConnStr"].ToString();
  19. }
  20. /// <summary>
  21. /// 查询列表
  22. /// </summary>
  23. /// <param name="relationData">关联表</param>
  24. /// <param name="condition">查询条件(sql语句)</param>
  25. /// <param name="count">总数(输出)</param>
  26. /// <param name="page">页码</param>
  27. /// <param name="limit">每页条数</param>
  28. /// <returns></returns>
  29. public List<Dictionary<string, object>> List(List<RelationData> relationData, string condition, out int count, int page = 1, int limit = 30, string orderBy = "Sort desc,Id desc")
  30. {
  31. List<string> fields = new List<string>(); //要显示的列
  32. fields.Add("Id");
  33. fields.Add("CreateDate"); //添加时间
  34. fields.Add("Status"); //状态
  35. fields.Add("ClientType"); //客户端类型
  36. fields.Add("Title"); //推送标题
  37. fields.Add("Details"); //推送内容
  38. fields.Add("TemplateId"); //模板
  39. Dictionary<string, object> obj = new DbService(AppConfig.Base.dbTables, _conn).IndexData("MsgPush", relationData, orderBy, page, limit, condition, fields);
  40. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  41. count = int.Parse(obj["count"].ToString());
  42. return diclist;
  43. }
  44. public List<Dictionary<string, object>> List(List<RelationData> relationData, string condition, int page = 1, int limit = 30, string orderBy = "Sort desc,Id desc")
  45. {
  46. List<string> fields = new List<string>(); //要显示的列
  47. fields.Add("Id");
  48. fields.Add("CreateDate"); //添加时间
  49. fields.Add("Status"); //状态
  50. fields.Add("ClientType"); //客户端类型
  51. fields.Add("Title"); //推送标题
  52. fields.Add("Details"); //推送内容
  53. fields.Add("TemplateId"); //模板
  54. Dictionary<string, object> obj = new DbService(AppConfig.Base.dbTables, _conn).IndexData("MsgPush", relationData, orderBy, page, limit, condition, fields);
  55. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  56. return diclist;
  57. }
  58. /// <summary>
  59. /// 查询一条记录
  60. /// </summary>
  61. /// <param name="Id">主键Id</param>
  62. /// <returns></returns>
  63. public MsgPush Query(int Id)
  64. {
  65. WebCMSEntities db = new WebCMSEntities();
  66. MsgPush editData = db.MsgPush.FirstOrDefault(m => m.Id == Id) ?? new MsgPush();
  67. db.Dispose();
  68. return editData;
  69. }
  70. /// <summary>
  71. /// 查询记录数
  72. /// </summary>
  73. /// <param name="Id">主键Id</param>
  74. /// <returns></returns>
  75. public int Count(string condition = "")
  76. {
  77. int result = 0;
  78. DataTable dt = CustomerSqlConn.dtable("select count(Id) from MsgPush where 1=1" + condition, _conn);
  79. if(dt.Rows.Count > 0)
  80. {
  81. result = int.Parse(function.CheckInt(dt.Rows[0][0].ToString()));
  82. }
  83. return result;
  84. }
  85. /// <summary>
  86. /// 查询是否存在
  87. /// </summary>
  88. /// <param name="Id">主键Id</param>
  89. /// <returns></returns>
  90. public bool Exist(int Id)
  91. {
  92. WebCMSEntities db = new WebCMSEntities();
  93. bool check = db.MsgPush.Any(m => m.Id == Id);
  94. db.Dispose();
  95. return check;
  96. }
  97. /// <summary>
  98. /// 添加数据
  99. /// </summary>
  100. /// <param name="Fields">要设置的字段</param>
  101. /// <returns></returns>
  102. public AppResultJson Add(Dictionary<string, object> fields, bool check = true)
  103. {
  104. if(check)
  105. {
  106. if (string.IsNullOrEmpty(fields["ClientType"].ToString()))
  107. {
  108. return new AppResultJson() { Status = "-1", Info = "请填写客户端类型" };
  109. }
  110. if (string.IsNullOrEmpty(fields["Title"].ToString()))
  111. {
  112. return new AppResultJson() { Status = "-1", Info = "请填写推送标题" };
  113. }
  114. if (string.IsNullOrEmpty(fields["Details"].ToString()))
  115. {
  116. return new AppResultJson() { Status = "-1", Info = "请填写推送内容" };
  117. }
  118. }
  119. int Id = new DbService(AppConfig.Base.dbTables, _conn).Add("MsgPush", fields, 0);
  120. return new AppResultJson(){ Status = "1", Data = Id };
  121. }
  122. /// <summary>
  123. /// 修改数据
  124. /// </summary>
  125. /// <param name="Fields">要设置的字段</param>
  126. /// <param name="Id">主键Id</param>
  127. public AppResultJson Edit(Dictionary<string, object> fields, int Id, bool check = true)
  128. {
  129. if(check)
  130. {
  131. if (string.IsNullOrEmpty(fields["ClientType"].ToString()))
  132. {
  133. return new AppResultJson() { Status = "-1", Info = "请填写客户端类型" };
  134. }
  135. if (string.IsNullOrEmpty(fields["Title"].ToString()))
  136. {
  137. return new AppResultJson() { Status = "-1", Info = "请填写推送标题" };
  138. }
  139. if (string.IsNullOrEmpty(fields["Details"].ToString()))
  140. {
  141. return new AppResultJson() { Status = "-1", Info = "请填写推送内容" };
  142. }
  143. }
  144. new DbService(AppConfig.Base.dbTables, _conn).Edit("MsgPush", fields, Id);
  145. return new AppResultJson(){ Status = "1", Data = Id };
  146. }
  147. /// <summary>
  148. /// 逻辑删除
  149. /// </summary>
  150. /// <param name="Id">主键Id</param>
  151. public void Remove(int Id)
  152. {
  153. Dictionary<string, object> fields = new Dictionary<string, object>();
  154. fields.Add("Status", -1);
  155. new DbService(AppConfig.Base.dbTables, _conn).Edit("MsgPush", fields, Id);
  156. }
  157. /// <summary>
  158. /// 删除数据
  159. /// </summary>
  160. /// <param name="Id">主键Id</param>
  161. public void Delete(int Id)
  162. {
  163. new DbService(AppConfig.Base.dbTables, _conn).Delete("MsgPush", Id);
  164. }
  165. /// <summary>
  166. /// 排序
  167. /// </summary>
  168. /// <param name="Id">主键Id</param>
  169. /// <param name="Sort">排序序号</param>
  170. public void Sort(int Id, int Sort)
  171. {
  172. new DbService(AppConfig.Base.dbTables, _conn).Sort("MsgPush", Sort, Id);
  173. }
  174. /// <summary>
  175. /// 导入数据
  176. /// </summary>
  177. /// <param name="ExcelData">json数据</param>
  178. public void Import(string ExcelData)
  179. {
  180. WebCMSEntities db = new WebCMSEntities();
  181. JsonData list = JsonMapper.ToObject(ExcelData);
  182. for (int i = 1; i < list.Count;i++ )
  183. {
  184. JsonData dr = list[i];
  185. db.MsgPush.Add(new MsgPush()
  186. {
  187. CreateDate = DateTime.Now,
  188. UpdateDate = DateTime.Now,
  189. });
  190. db.SaveChanges();
  191. }
  192. db.Dispose();
  193. }
  194. /// <summary>
  195. /// 导出excel表格
  196. /// </summary>
  197. /// <param name="fields">查询条件(单个字段)</param>
  198. /// <param name="condition">查询条件(sql语句)</param>
  199. /// <returns></returns>
  200. // public void ExportExcel(List<RelationData> relationData, string condition)
  201. // {
  202. // }
  203. }
  204. }