DataClearHandler.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. using DbHelper;
  2. using SqlSugar;
  3. using System;
  4. using System.ComponentModel;
  5. using WCS.BaseExtensions;
  6. using WCS.Core;
  7. using WCS.Entity;
  8. namespace WCS.Service
  9. {
  10. [Description("数据清理")]
  11. internal class DataClearHandler : LogicHandler
  12. {
  13. public override void Start()
  14. {
  15. }
  16. private DateTime last = DateTime.MinValue;
  17. public override void Update(double milliseconds)
  18. {
  19. if ((DateTime.Now - last).TotalMilliseconds < 1000 * 60 * 60 * 24)
  20. return;
  21. last = DateTime.Now;
  22. Db.Do(db =>
  23. {
  24. db.Default.Deleteable<WCS_EXCEPTION>().Where(v => SqlFunc.DateDiff(DateType.Day, v.UPDATETIME, SqlFunc.GetDate()) > 7).AddQueue();
  25. //db.Default.Ado.UseStoredProcedure().ExecuteCommand("DELETE FROM wcs_exception WHERE TIMESTAMPDIFF(DAY,UPDATETIME,NOW()) > 7");
  26. var ps = db.Default.GetType().GetProperties();
  27. foreach (var p in ps)
  28. {
  29. if (!p.PropertyType.IsGenericType)
  30. continue;
  31. var tType = p.PropertyType.GenericTypeArguments[0];
  32. if (!tType.IsSubclassOf(typeof(WCS_PROTOCOLDATA)))
  33. continue;
  34. var sSql = $"Delete FROM {tType.Name} where TIMESTAMPDIFF(DAY,Frame,NOW())>7";
  35. db.Default.Ado.UseStoredProcedure().ExecuteCommand(sSql);
  36. DbHelper.DbLog.DB_CLEAN(sSql);
  37. }
  38. var taskList = db.Default.Queryable<WCS_TASK>().Where(v => SqlFunc.DateDiff(DateType.Day, v.UPDATETIME, SqlFunc.GetDate()) > 3 && v.STATUS >= TaskStatus.已完成).ToList();
  39. foreach (var task in taskList)
  40. {
  41. var taskOld = TypeExtension.Mapper<WCS_TASK_OLD, WCS_TASK>(task);
  42. db.Default.Insertable(taskOld).AddQueue();
  43. db.Default.Deleteable(task).AddQueue();
  44. }
  45. db.Default.SaveQueues();
  46. });
  47. }
  48. }
  49. }