一尘不染

实体框架会创建一个复数表名,但是视图需要一个单数表名吗?

mysql

我正在使用MySQL .net连接器6.4.4.0和Entity Frame工作4.1,并尝试创建最基本的代码优先实现。

public class myDB: DbContext
{
    public DbSet<Vote> Votes { get; set; }
}

我的模特

public class Vote
{
    public Guid Id { get; set; }
    public int Value { get; set; }
}

我的家庭控制器

public class HomeController : Controller
{
    myDB_db = new myDB();
    public ActionResult Index()
    {
        var model = _db.Votes;
        return View(model);
    }
}

我的强类型视图(使用List脚手架)

@model IEnumerable<Namespace.Models.Vote>

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>
<table>
    <tr>
        <th>
            @Html.DisplayNameFor(model => model.Value)
        </th>
        <th></th>
    </tr>

    @foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.Value)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new { id=item.Id }) |
            @Html.ActionLink("Details", "Details", new { id=item.Id }) |
            @Html.ActionLink("Delete", "Delete", new { id=item.Id })
        </td>
    </tr>
    }

</table>

它在mySQL中使用所有正确的属性创建表“ votes”。

但是,它抛出这一行:

@foreach(模型中的var项)

有这个特例:

“表’mydb.vote’不存在”

编辑:澄清一下,我实际上是想要表的复数形式,并且似乎可以正确地创建表。我希望发现单数/复数差异的原因。microsoft / Plural Sight /
scott gu的教程和视频都没有使用mysql处理的,所以我不得不想象.netconnector可能是罪魁祸首。我也想避免使用[Table(“
Votes”)]属性。基本上,我希望有尽可能多的“开箱即用”的解决方案。

edit2(一些更相关的代码):当我删除此…表无法一起创建。但是该视图引发了一个异常,即寻找“投票”而不是“投票”。在global.asax中

protected void Application_Start()
{
     Database.SetInitializer(new DropCreateDatabaseAlways<myDB>());

     AreaRegistration.RegisterAllAreas();
     RegisterGlobalFilters(GlobalFilters.Filters);
     RegisterRoutes(RouteTable.Routes);
}

public class myDBInitializer : DropCreateDatabaseAlways<myDB>
{
    protected override void Seed(myDBcontext)
    {
        base.Seed(context);
    }
}

阅读 279

收藏
2020-05-17

共1个答案

一尘不染

因此,我放弃了尝试以自己认为应该做的方式来做,并一起消除了多元化。我不确定,但我认为问题与EF的mysql .net连接器有关。这是我所做的。

首先,我的ApplicationStart方法中存在一个错误:

//WRONG
//Database.SetInitializer(new DropCreateDatabaseAlways<myDB>());
Database.SetInitializer(new myDBInitializer());

其次,我不再调用原始代码中未列出的OnModelCreating基本实现,因为我仅按照jgauffin的建议实现了它:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    //DONT DO THIS ANYMORE
    //base.OnModelCreating(modelBuilder);
    //modelBuilder.Entity<Vote>().ToTable("Votes")
    modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
}

第三,我在一些帖子中读到,MySQL .net
Connector不允许EF实际创建数据库,因此我最初创建了空白数据库。连接器6.4.4+似乎不再是这种情况,并且只要您的连接字符串的用户具有创建新数据库的能力,如果最初不存在数据库,它的性能就会更好。

一次,我完成了以上所有操作,它似乎起作用了。所以现在我至少可以前进了。希望我们将来能找出造成复数/单数差异的原因。

感谢大家的时间和精力。

2020-05-17