Lir*_*man 2 c# entity-framework-core asp.net-core
我正在开始使用 EF core 的新项目。我在 MSSQL 服务器上有一个现有数据库,我运行此命令以包含其 EF 结构。
Scaffold-DbContext "Server={My Server};Database={My DB};Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer
Run Code Online (Sandbox Code Playgroud)
这为我创建了模型类,例如:
public partial class Cameras
{
public int CameraId { get; set; }
public string Description { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
以及以下上下文类:
public partial class SetupToolContext : DbContext
{
public virtual DbSet<Cameras> Cameras { get; set; }
public SetupToolContext(DbContextOptions<SetupToolContext> options) : base(options)
{ }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Cameras>(entity =>
{
entity.HasKey(e => e.CameraId)
.HasName("PK_Cameras");
entity.Property(e => e.Description).HasColumnType("varchar(500)");
});
}
}
Run Code Online (Sandbox Code Playgroud)
我的解决方案有 4 层:
我的代码中的流程如下:
控制器类
public class ValuesController : Controller
{
ICameraRepository cameraRepository;
public ValuesController(ICameraRepository cameraRepository)
{
this.cameraRepository = cameraRepository;
}
[HttpGet]
public IEnumerable<Cameras> Get()
{
//ERROR: "Invalid object name 'Cameras'."
return cameraRepository.List();
}
}
Run Code Online (Sandbox Code Playgroud)
相机存储库类
public class CamerasRepository : GenericRepository<Cameras>, ICameraRepository
{
private readonly SetupToolContext dbContext;
public CamerasRepository(SetupToolContext dbContext) : base(dbContext)
{
this.dbContext = dbContext;
}
}
public interface ICameraRepository : IRepository<Cameras>
{ }
Run Code Online (Sandbox Code Playgroud)
GenericRepository 类(尝试遵循存储库模式)
public class GenericRepository<T> : IRepository<T> where T : class
{
private readonly SetupToolContext dbContext;
public GenericRepository(SetupToolContext dbContext)
{
this.dbContext = dbContext;
}
public IEnumerable<T> List()
{
return dbContext.Set<T>().AsEnumerable();
}
}
public interface IRepository<T>
{
IEnumerable<T> List();
}
Run Code Online (Sandbox Code Playgroud)
和Startup类的ConfigureServices方法
public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext<SetupToolContext>(options => options.UseSqlServer(Configuration.GetConnectionString("SQLServerConnection")));
services.AddMvc();
services.AddScoped<ICameraRepository, CamerasRepository>();
}
Run Code Online (Sandbox Code Playgroud)
问题是我收到错误:"Invalid object name 'Cameras'."
说起来有点尴尬,但我仍然会发布这个答案,以防其他人因为没有注意到这个“小”细节而出现同样的错误。我有 2 个数据库,结果我忘记将连接字符串中的数据库名称更改为正确的数据库名称。我在Scaffold-DbContext命令中更改了它,只是忘记在连接字符串中也更改它......
{
"ConnectionStrings": {
"SQLServerConnection": "Server=localhost;Database={I had the wrong db name here};Trusted_Connection=True;"
}
}
Run Code Online (Sandbox Code Playgroud)
因此,将其更改为正确的解决方案。
| 归档时间: |
|
| 查看次数: |
5916 次 |
| 最近记录: |