SqlException: 无效的对象名称 Person.Person

问题描述

我正在按照 this 教程使用 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:无效的对象名称 '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]

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

解决方法

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

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

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")));
    }

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...