Job_SqlExecute.cs 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using Infrastructure;
  2. using Infrastructure.Attribute;
  3. using Infrastructure.Extensions;
  4. using Quartz;
  5. using Quartz.Impl;
  6. using Quartz.Impl.Triggers;
  7. using SqlSugar.IOC;
  8. using System;
  9. using System.Threading.Tasks;
  10. using ZR.Service.System.IService;
  11. namespace ZR.Tasks.TaskScheduler
  12. {
  13. [AppService(ServiceType = typeof(Job_SqlExecute), ServiceLifetime = LifeTime.Scoped)]
  14. public class Job_SqlExecute : JobBase, IJob
  15. {
  16. private readonly ISysTasksQzService tasksQzService;
  17. private readonly NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger();
  18. public Job_SqlExecute(ISysTasksQzService tasksQzService)
  19. {
  20. this.tasksQzService = tasksQzService;
  21. }
  22. public async Task Execute(IJobExecutionContext context)
  23. {
  24. await ExecuteJob(context, async () => await Run(context));
  25. }
  26. public async Task Run(IJobExecutionContext context)
  27. {
  28. AbstractTrigger trigger = (context as JobExecutionContextImpl).Trigger as AbstractTrigger;
  29. var info = await tasksQzService.GetByIdAsync(trigger.JobName);
  30. if (info != null && info.SqlText.IsNotEmpty())
  31. {
  32. var result = DbScoped.SugarScope.Ado.ExecuteCommandWithGo(info.SqlText);
  33. logger.Info($"任务【{info.Name}】sql请求执行结果=" + result);
  34. }
  35. else
  36. {
  37. throw new CustomException($"任务{trigger?.JobName}执行失败,任务不存在");
  38. }
  39. }
  40. }
  41. }