TrendChartManage.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.Common;
  5. using CB.Common;
  6. using CB.Entity;
  7. using CB.Interface.Infrastructure;
  8. namespace CB.Data.SqlServer
  9. {
  10. public class TrendChartManage : Repository<TrendChartInfo>, ITrendChartService
  11. {
  12. public TrendChartManage(string interfaceId)
  13. : base(interfaceId)
  14. {
  15. }
  16. public override bool Save(TrendChartInfo entity)
  17. {
  18. DbParameter[] pars =
  19. {
  20. DbHelper.MakeInParam(InterfaceId,"@Name",(DbType)SqlDbType.NChar,20,entity.Name),
  21. DbHelper.MakeInParam(InterfaceId,"@Cid",(DbType)SqlDbType.Int,4,entity.Cid),
  22. DbHelper.MakeInParam(InterfaceId,"@Tid",(DbType)SqlDbType.Int,4,entity.Tid),
  23. DbHelper.MakeInParam(InterfaceId,"@Status",(DbType)SqlDbType.Int,4,(int)entity.Status),
  24. DbHelper.MakeInParam(InterfaceId,"@OrderBy",(DbType)SqlDbType.Int,4,entity.OrderBy),
  25. DbHelper.MakeInParam(InterfaceId,"@Url",(DbType)SqlDbType.NVarChar,200,entity.Url),
  26. DbHelper.MakeInParam(InterfaceId,"@Type",(DbType)SqlDbType.Int,4,(int)entity.Type),
  27. DbHelper.MakeInParam(InterfaceId,"@hTitle",(DbType)SqlDbType.NVarChar,500,entity.hTitle),
  28. DbHelper.MakeInParam(InterfaceId,"@hKeywords",(DbType)SqlDbType.NVarChar,500,entity.hKeywords),
  29. DbHelper.MakeInParam(InterfaceId,"@hDescription",(DbType)SqlDbType.NVarChar,500,entity.hDescription),
  30. DbHelper.MakeInParam(InterfaceId,"@Direction",(DbType)SqlDbType.Int,4,entity.Direction),
  31. DbHelper.MakeInParam(InterfaceId,"@TemplateId",(DbType)SqlDbType.Int,4,entity.TemplateId)
  32. };
  33. return DbHelper.ExecuteNonQuery(InterfaceId, CommandType.Text,
  34. @"INSERT INTO [DT_TrendChart]([Name],[Cid],[Tid],[Status],[OrderBy],[Url],[Type],[hTitle],[hKeywords],[hDescription],[Direction],[TemplateId])
  35. VALUES (@Name,@Cid,@Tid,@Status,@OrderBy,@Url,@Type,@hTitle,@hKeywords,@hDescription,@Direction,@TemplateId)", pars) > 0 ? true : false;
  36. }
  37. public override bool Update(TrendChartInfo entity)
  38. {
  39. DbParameter[] pars =
  40. {
  41. DbHelper.MakeInParam(InterfaceId,"@Id",(DbType)SqlDbType.Int,4,entity.Id),
  42. DbHelper.MakeInParam(InterfaceId,"@Name",(DbType)SqlDbType.NChar,20,entity.Name),
  43. DbHelper.MakeInParam(InterfaceId,"@Cid",(DbType)SqlDbType.Int,4,entity.Cid),
  44. DbHelper.MakeInParam(InterfaceId,"@Tid",(DbType)SqlDbType.Int,4,entity.Tid),
  45. DbHelper.MakeInParam(InterfaceId,"@Status",(DbType)SqlDbType.Int,4,(int)entity.Status),
  46. DbHelper.MakeInParam(InterfaceId,"@OrderBy",(DbType)SqlDbType.Int,4,entity.OrderBy),
  47. DbHelper.MakeInParam(InterfaceId,"@Url",(DbType)SqlDbType.NVarChar,200,entity.Url),
  48. DbHelper.MakeInParam(InterfaceId,"@Type",(DbType)SqlDbType.Int,4,(int)entity.Type),
  49. DbHelper.MakeInParam(InterfaceId,"@hTitle",(DbType)SqlDbType.NVarChar,500,entity.hTitle),
  50. DbHelper.MakeInParam(InterfaceId,"@hKeywords",(DbType)SqlDbType.NVarChar,500,entity.hKeywords),
  51. DbHelper.MakeInParam(InterfaceId,"@hDescription",(DbType)SqlDbType.NVarChar,500,entity.hDescription),
  52. DbHelper.MakeInParam(InterfaceId,"@Direction",(DbType)SqlDbType.Int,4,entity.Direction),
  53. DbHelper.MakeInParam(InterfaceId,"@TemplateId",(DbType)SqlDbType.Int,4,entity.TemplateId)
  54. };
  55. return DbHelper.ExecuteNonQuery(InterfaceId, CommandType.Text,
  56. @"UPDATE [DT_TrendChart] SET [Name]=@Name,[Cid]=@Cid,[Tid]=@Tid,[Status]=@Status,[OrderBy]=@OrderBy,[Url]=@Url,
  57. [Type]=@Type,[hTitle]=@hTitle,[hKeywords]=@hKeywords,[hDescription]=@hDescription,[Direction]=@Direction,[TemplateId]=@TemplateId WHERE [Id]=@Id", pars) > 0 ? true : false;
  58. }
  59. public override bool Delete(int Id)
  60. {
  61. DbParameter[] pars =
  62. {
  63. DbHelper.MakeInParam(InterfaceId,"@statement",(DbType)SqlDbType.NVarChar,50,"DELETE FROM [DT_TrendChart] WHERE [Id]=@Id"),
  64. DbHelper.MakeInParam(InterfaceId,"@params",(DbType)SqlDbType.NVarChar,10,"@Id int"),
  65. DbHelper.MakeInParam(InterfaceId,"@Id",(DbType)SqlDbType.Int,4,Id)
  66. };
  67. return DbHelper.ExecuteNonQuery(InterfaceId,CommandType.StoredProcedure, "dbo.sp_executesql", pars) > 0 ? true : false;
  68. }
  69. public override TrendChartInfo Get<TKey>(TKey key)
  70. {
  71. TrendChartInfo Entity = null;
  72. DbParameter[] para =
  73. {
  74. DbHelper.MakeInParam(InterfaceId,"@id",(DbType)SqlDbType.Int,4,key)
  75. };
  76. IDataReader reader = DbHelper.ExecuteReader(InterfaceId,CommandType.Text,
  77. "SELECT TOP 1 [Id],[Name],[Cid],[Tid],[Status],[Type],[OrderBy],[hTitle],[hKeywords],[hDescription],[Url],[Direction],[TemplateId] FROM [DT_TrendChart] WHERE id= @id", para);
  78. if (reader.Read())
  79. {
  80. Entity = LoadEntity(reader);
  81. }
  82. return Entity;
  83. }
  84. public TrendChartInfo Get(TrendChartInfo entity)
  85. {
  86. TrendChartInfo reInfo = null;
  87. string sql = "SELECT TOP 1 [Id],[Name],[Cid],[Tid],[Status],[Type],[OrderBy],[hTitle],[hKeywords],[hDescription],[Url],[Direction],[TemplateId] FROM [DT_TrendChart] WHERE 1=1 ";
  88. if (!string.IsNullOrEmpty(entity.Name))
  89. {
  90. sql += " AND [Name]='" + entity.Name + "'";
  91. }
  92. if (0 < entity.Cid)
  93. {
  94. sql += " AND [Cid]=" + entity.Cid;
  95. }
  96. if (0 < entity.Tid)
  97. {
  98. sql += " AND [Tid]=" + entity.Tid;
  99. }
  100. sql += " ORDER BY OrderBy";
  101. using (IDataReader reader = DbHelper.ExecuteReader(InterfaceId,CommandType.Text, sql))
  102. {
  103. if (reader.Read())
  104. {
  105. reInfo = LoadEntity(reader);
  106. }
  107. }
  108. return reInfo;
  109. }
  110. public override IList<TrendChartInfo> ToList()
  111. {
  112. IList<TrendChartInfo> list = new List<TrendChartInfo>();
  113. using (IDataReader reader = DbHelper.ExecuteReader(InterfaceId,CommandType.Text,
  114. "SELECT [Id],[Name],[Cid],[Tid],[Status],[Type],[OrderBy],[hTitle],[hKeywords],[hDescription],[Url],[Direction],[TemplateId] FROM [DT_TrendChart] ORDER BY [OrderBy] ASC"))
  115. {
  116. while (reader.Read())
  117. { list.Add(LoadEntity(reader)); }
  118. }
  119. return list;
  120. }
  121. public override IList<TrendChartInfo> ToList(TrendChartInfo entity)
  122. {
  123. throw new NotImplementedException();
  124. }
  125. public override IList<TrendChartInfo> ToPaging(TrendChartInfo entity, int pageSize, int pageIndex, out int recordCount)
  126. {
  127. recordCount = 0;
  128. IList<TrendChartInfo> list = new List<TrendChartInfo>();
  129. string where = "1=1 ";
  130. if (null != entity)
  131. {
  132. if (!string.IsNullOrEmpty(entity.Name))
  133. {
  134. where += " AND [Name] Like '%" + entity.Name + "%'";
  135. }
  136. if (0 < entity.Cid)
  137. {
  138. where += " AND [Cid]=" + entity.Cid;
  139. }
  140. if (0 < entity.Tid)
  141. {
  142. where += " AND [Tid]=" + entity.Tid;
  143. }
  144. }
  145. DbParameter[] pars ={
  146. DbHelper.MakeInParam(InterfaceId,"@pageSize",(DbType)SqlDbType.Int,4,pageSize),
  147. DbHelper.MakeInParam(InterfaceId,"@page",(DbType)SqlDbType.Int,4,pageIndex),
  148. DbHelper.MakeInParam(InterfaceId,"@tableName",(DbType)SqlDbType.NVarChar,500,"[DT_TrendChart]"),
  149. DbHelper.MakeInParam(InterfaceId,"@field",(DbType)SqlDbType.NVarChar,1000,
  150. "[Id],[Name],[Cid],[Tid],[Status],[Type],[OrderBy],[hTitle],[hKeywords],[hDescription],[Url],[Direction],[TemplateId]"),
  151. DbHelper.MakeInParam(InterfaceId,"@orderField",(DbType)SqlDbType.NVarChar,50,"[Cid],[Id] ASC"),
  152. DbHelper.MakeInParam(InterfaceId,"@where",(DbType)SqlDbType.NVarChar,2000,where)
  153. };
  154. using (IDataReader reader = DbHelper.ExecuteReader(InterfaceId,CommandType.StoredProcedure, "usp_st_page", pars))
  155. {
  156. while (reader.Read())
  157. {
  158. list.Add(LoadEntity(reader));
  159. }
  160. if (reader.NextResult() && reader.Read())
  161. {
  162. recordCount = reader.GetInt32(0);
  163. }
  164. }
  165. return list;
  166. }
  167. public void UpdateTrendSmart(int startId, int endId)
  168. {
  169. DbParameter[] pars ={
  170. DbHelper.MakeInParam(InterfaceId,"@startid",(DbType)SqlDbType.Int,4,startId),
  171. DbHelper.MakeInParam(InterfaceId,"@endid",(DbType)SqlDbType.Int,4,endId)
  172. };
  173. DbHelper.ExecuteNonQuery(InterfaceId, CommandType.StoredProcedure, "usp_TrendSmart_update", pars);
  174. }
  175. public IList<TrendChartInfo> GetTrendSmartList(int chartId, int topSize)
  176. {
  177. DbParameter[] pars =
  178. {
  179. DbHelper.MakeInParam(InterfaceId,"@statement",(DbType)SqlDbType.NVarChar,300,
  180. @"SELECT TOP (@topSize) [Id],[Name],[Cid],[Tid],[Status],[Type],[OrderBy],[hTitle],[hKeywords],[hDescription],[Url],[Direction],[TemplateId] FROM [DT_TrendChart]
  181. WHERE [Id] IN (SELECT TOP (@topSize) [EndId] FROM [DT_TrendSmart] WHERE [StartId]=@chartId ORDER BY [Hits] DESC) ORDER BY [Id]"),
  182. DbHelper.MakeInParam(InterfaceId,"@params",(DbType)SqlDbType.NVarChar,30,"@topSize int,@chartId int"),
  183. DbHelper.MakeInParam(InterfaceId,"@topSize",(DbType)SqlDbType.Int,4,topSize),
  184. DbHelper.MakeInParam(InterfaceId,"@chartId",(DbType)SqlDbType.Int,4,chartId)
  185. };
  186. IList<TrendChartInfo> list = new List<TrendChartInfo>();
  187. using (IDataReader reader = DbHelper.ExecuteReader(InterfaceId, CommandType.StoredProcedure, "dbo.sp_executesql", pars))
  188. {
  189. while (reader.Read())
  190. {
  191. list.Add(LoadEntity(reader));
  192. }
  193. reader.Close();
  194. }
  195. return list;
  196. }
  197. protected override TrendChartInfo LoadEntity(IDataReader reader)
  198. {
  199. return new TrendChartInfo
  200. {
  201. Id = TypeConverter.ObjectToInt(reader["Id"]),
  202. Name = reader["Name"].ToString().Trim(),
  203. Cid = TypeConverter.ObjectToInt(reader["Cid"]),
  204. Tid = TypeConverter.ObjectToInt(reader["Tid"]),
  205. Status = (TrendChartStatus)Enum.Parse(typeof(TrendChartStatus), reader["Status"].ToString()),
  206. Type = (TrendChartIdType)Enum.Parse(typeof(TrendChartIdType), reader["type"].ToString()),
  207. OrderBy = TypeConverter.ObjectToInt(reader["OrderBy"]),
  208. hTitle = reader["hTitle"].ToString().Trim(),
  209. hKeywords = reader["hKeywords"].ToString().Trim(),
  210. hDescription = reader["hDescription"].ToString().Trim(),
  211. Url = reader["Url"].ToString().Trim(),
  212. Direction = TypeConverter.ObjectToInt(reader["Direction"]),
  213. TemplateId = TypeConverter.ObjectToInt(reader["TemplateId"])
  214. };
  215. }
  216. protected override TrendChartInfo LoadEntity(DataRow dr)
  217. {
  218. return new TrendChartInfo
  219. {
  220. Id = TypeConverter.ObjectToInt(dr["Id"]),
  221. Name = dr["Name"].ToString().Trim(),
  222. Cid = TypeConverter.ObjectToInt(dr["Cid"]),
  223. Tid = TypeConverter.ObjectToInt(dr["Tid"]),
  224. Status = (TrendChartStatus)Enum.Parse(typeof(TrendChartStatus), dr["Status"].ToString()),
  225. Type = (TrendChartIdType)Enum.Parse(typeof(TrendChartIdType), dr["type"].ToString()),
  226. OrderBy = TypeConverter.ObjectToInt(dr["OrderBy"]),
  227. hTitle = dr["hTitle"].ToString().Trim(),
  228. hKeywords = dr["hKeywords"].ToString().Trim(),
  229. hDescription = dr["hDescription"].ToString().Trim(),
  230. Url = dr["Url"].ToString().Trim(),
  231. Direction = TypeConverter.ObjectToInt(dr["Direction"]),
  232. TemplateId = TypeConverter.ObjectToInt(dr["TemplateId"])
  233. };
  234. }
  235. }
  236. }