首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何创建代码优先DbContext的视图?

如何创建代码优先DbContext的视图?
EN

Stack Overflow用户
提问于 2018-08-15 03:41:01
回答 1查看 126关注 0票数 1

在Database-First中,将视图添加到EDMX中相对容易。我们如何在Code-First中做到这一点?

我们可以在自定义迁移类中使用Code First创建视图。

代码语言:javascript
复制
public partial class AddNewView : DbMigration
{
    public override void Up()
    {
        Sql("CREATE VIEW [dbo].[NewView] AS ...");
    }

    public override void Down()
    {
        Sql("DROP VIEW dbo.[NewView]");
    }
}

但是,我们如何访问DbContext中的视图呢?

对于表,我们可以将域模型添加到DbContext中并进行一些配置。

代码语言:javascript
复制
public virtual DbSet<Person> Persons { get; set; }

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Configurations.Add(new PersonConfiguration());
}

将视图添加到DbContext的正确方法是什么?

EN

回答 1

Stack Overflow用户

发布于 2018-08-15 18:16:21

这感觉有点老土,但我最终要做的是:

  • 创建具有表示视图的所有属性的模型。
  • public virtual DbSet<TableName> TableNames { get; }添加到迁移中的Up()Down()方法。

并添加视图创建/删除SQL脚本:

代码语言:javascript
复制
public override void Up(MigrationBuilder migrationBuilder)
{
    migrationBuilder.Sql("CREATE VIEW [dbo].[NewView] AS ...");
}
public override void Down(MigrationBuilder migrationBuilder)
{
    migrationBuilder.Sql("DROP VIEW dbo.[NewView]");
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51848704

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档