我正在按照 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]
我只是不知道这个错误是从哪里来的。 提前致谢
答案 0 :(得分: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")));
}
这就是注入的上下文不起作用的原因。