DataClearHandler.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. using DBHelper;
  2. using Microsoft.EntityFrameworkCore;
  3. using System;
  4. using System.ComponentModel;
  5. using WCS.Core;
  6. using WCS.Entity;
  7. namespace WCS.Service
  8. {
  9. [Description("数据清理")]
  10. internal class DataClearHandler : LogicHandler
  11. {
  12. public override void Start()
  13. {
  14. }
  15. private DateTime last = DateTime.MinValue;
  16. public override void Update(double milliseconds)
  17. {
  18. if ((DateTime.Now - last).TotalMilliseconds < 1000 * 60 * 60 * 24)
  19. return;
  20. last = DateTime.Now;
  21. DB.Do(db =>
  22. {
  23. db.Default.Database.ExecuteSqlRaw("delete WCS_EXCEPTION where datediff(dd,UPDATETIME,getdate())>2");
  24. db.Default.Database.ExecuteSqlRaw("delete WCS_StatusLog where datediff(dd,UPDATETIME,getdate())>365");
  25. var ps = db.Default.GetType().GetProperties();
  26. foreach (var p in ps)
  27. {
  28. if (!p.PropertyType.IsGenericType)
  29. continue;
  30. var tType = p.PropertyType.GenericTypeArguments[0];
  31. if (!tType.IsSubclassOf(typeof(WCS_PROTOCOLDATA)))
  32. continue;
  33. var sSql = $"Delete {tType.Name} where datediff(dd,Frame,getdate())>2";
  34. db.Default.Database.ExecuteSqlRaw(sSql);
  35. DBHelper.DbLog.DB_CLEAN(sSql);
  36. }
  37. var copySql = @"INSERT INTO WCS_TASK_OLD (ID,BARCODE,TYPE,STATUS,ADDRFROM,ADDRTO,ADDRNEXT,TUNNEL,FLOOR,
  38. DEVICE,SRMSTATION,CREATETIME,STARTTIME,ENDTIME,DOCID,PALLETTYPE,PRODLINE,FULLQTY,HEIGHT,
  39. WMSTASK,TaskGroupKey,UPLOADED,AgvTask,Priority,ManualRemarks,ENABLED,UPDATEUSER,UPDATETIME,
  40. Length,MaterialCode) SELECT
  41. ID,BARCODE,TYPE,STATUS,ADDRFROM,ADDRTO,ADDRNEXT,TUNNEL,FLOOR,DEVICE,SRMSTATION,CREATETIME,
  42. STARTTIME,ENDTIME,DOCID,PALLETTYPE,PRODLINE,FULLQTY,HEIGHT,WMSTASK,TaskGroupKey,UPLOADED,AgvTask,
  43. Priority,ManualRemarks,ENABLED,UPDATEUSER,UPDATETIME,Length,MaterialCode FROM WCS_TASK WHERE STATUS >=99 AND UPDATETIME < DATEADD(HOUR, -1, GETDATE())";
  44. db.Default.Database.ExecuteSqlRaw(copySql);
  45. var clearSql = "DELETE FROM WCS_TASK WHERE STATUS >=99 AND UPDATETIME < DATEADD(HOUR, -1, GETDATE())";
  46. db.Default.Database.ExecuteSqlRaw(clearSql);
  47. });
  48. }
  49. }
  50. }