簡體   English   中英

添加每 7 天刪除一次數據的后台服務

[英]Adding a background service that deletes data every 7 days

我有一個 class Issue ,其中包含一些信息,包括它們的日期。 我想創建一個后台服務,從數據庫中刪除超過 7 天的數據。

這是我試過的代碼:

using APIExample;
using Microsoft.Identity.Client;

public class BackgroundWorker : BackgroundService
{
    private readonly AppDbContext _appDbContext;

    public BackgroundWorker(AppDbContext appDbContext)
    {
        _appDbContext = appDbContext;
    }

    protected override Task ExecuteAsync(CancellationToken stoppingToken)
    {
        _appDbContext.Issue.RemoveRange(_appDbContext.Issue.Where(a => (a.Created.AddDays(7) >= DateTime.Now)));
        _appDbContext.SaveChanges();
        return Task.CompletedTask;
    }
}

我已經在program.cs中注入了這個 class

builder.Services.AddHostedService<BackgroundWorker>();

這是我得到的錯誤:

System.AggregateException:'無法構建某些服務(驗證服務描述符'ServiceType:Microsoft.Extensions.Hosting.IHostedService Lifetime:Singleton ImplementationType:BackgroundWorker'時出錯:無法使用來自singleton的范圍服務'APIExample.AppDbContext' Microsoft.Extensions.Hosting.IHostedService'.)'

你不能像這樣注入 DbContext,使用 ServiceScopeFactory

        public class BackgroundWorker : BackgroundService
        {
          private readonly IServiceScopeFactory _serviceScopeFactory;
    
        
            public BackgroundWorker(IServiceScopeFactory serviceScopeFactory)
            {
                _serviceScopeFactory = serviceScopeFactory;
            }
        
            protected override Task ExecuteAsync(CancellationToken stoppingToken)
            {
            using (var scope = _serviceScopeFactory.CreateScope())
            {
                 var _appDbContext= scope.ServiceProvider.GetService<AppDbContext>();
                _appDbContext.Issue.RemoveRange(_appDbContext.Issue.Where(a => (a.Created.AddDays(7) >= DateTime.Now)));
                _appDbContext.SaveChanges();
                return Task.CompletedTask;
            }
        }
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM