1

我正在按照教程使用 Visual Studio 2019 项目模板在 AspNet Core 3.1 中创建示例 API,但由于我使用的是 AdventureWorks (2019) 数据库,因此我不得不进行一些更改。

数据库上下文是这样搭建的。

public partial class AdventureWorks2019Context : DbContext
{
   public AdventureWorks2019Context(){}

   public AdventureWorks2019Context(DbContextOptions<AdventureWorks2019Context> options)
            : base(options){}
   .
   .
   .
   public virtual DbSet<Person> Person { get; set; }
   .
   .
   .
}

然后我在startup.cs中注册了这个上下文,如下所示:

public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();

        services.AddDbContext<AdventureWorks2019Context>(
            options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
    }

我还搭建了一个 People 控制器,但是当我尝试 GetPerson() 方法时它不起作用,我收到“SqlException: Invalid object name 'Person.Person'”错误消息。

[HttpGet]
public async Task<ActionResult<IEnumerable<Person>>> GetPerson()
   {
     return await _context.Person.ToListAsync(); //==> SqlException: Invalid object name 'Person.Person'.
   }

这就是错误SqlException: Invalid object name 'Person.Person'。 但是当我这样做(如下)时,它会起作用。但是,我不想这样做,因为我会错过依赖注入的全部意义,就像我看到的那样。

[HttpGet]
public async Task<ActionResult<IEnumerable<Person>>> GetPerson()
{
    AdventureWorks2019Context awc = new AdventureWorks2019Context();
    return await awc.Person.ToListAsync();//==> Works fine
}

无论哪种情况,发送到 SQL Server 的都是这个,它工作正常。

SELECT [p].[BusinessEntityID], 
[p].[AdditionalContactInfo], 
[p].[Demographics], 
[p].[EmailPromotion], 
[p].[FirstName], 
[p].[LastName], 
[p].[MiddleName], 
[p].[ModifiedDate], 
[p].[NameStyle], 
[p].[PersonType], 
[p].[rowguid], 
[p].[Suffix], 
[p].[Title]
FROM [Person].[Person] AS [p]

我只是不知道这个错误来自哪里。提前致谢

4

1 回答 1

0

长话短说,问题是我正在处理两个不同的连接字符串。

脚手架的数据上下文使用的是硬编码的连接字符串,这没问题,所以当我手动创建上下文而不是注入它时它可以工作。

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
    if (!optionsBuilder.IsConfigured)
    {
        optionsBuilder.UseSqlServer("Data Source=cougar-one\\dev01;Initial Catalog=AdventureWorks2019;Integrated Security=True");
    }
}

但是,当我继续在StartUp.cs上注册它时,我使用了一个名为“ DefaultConnection ”的连接字符串,它指向一个完全不同的数据库。

 public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();

        services.AddDbContext<AdventureWorks2019Context>(
            options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
    }

这就是为什么注入的上下文不起作用的原因。

于 2020-12-23T07:14:44.323 回答