首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用实体框架在数据库中创建表

使用实体框架在数据库中创建表
EN

Stack Overflow用户
提问于 2013-12-10 00:11:51
回答 3查看 26.7K关注 0票数 4

我正在尝试使用Entity Framework将我的MVC项目与数据库相链接,但我不知道如何将新记录存储到数据库中。到目前为止,我有以下代码:

代码语言:javascript
复制
//model

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using MvcApplication1.Controllers;

namespace MvcApplication1.Models
{
public class CarUser
{
    public int ID { get; set; }
    [DisplayName ("First Name")]
    public string Fname { get; set; }
    [DisplayName ("Surname")]
    public string Sname { get; set; }
}
}

//controller

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MvcApplication1.Models;

namespace MvcApplication1.Controllers
{
public class CarUserController : Controller
{
    private FormDataContext db = new FormDataContext();

    //
    // GET: /CarUser/

    public ActionResult Index()
    {
        return View(db.CarUsers.ToList());
    }

    //
    // GET: /CarUser/Details/5

    public ActionResult Details(int id = 0)
    {
        CarUser caruser = db.CarUsers.Find(id);
        if (caruser == null)
        {
            return HttpNotFound();
        }
        return View(caruser);
    }

    //
    // GET: /CarUser/Create

    public ActionResult Create()
    {
        return View();
    }

    //
    // POST: /CarUser/Create

    [HttpPost]
    public ActionResult Create(CarUser caruser)
    {
        if (ModelState.IsValid)
        {
            db.CarUsers.Add(caruser);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        return View(caruser);
    }

    //
    // GET: /CarUser/Edit/5

    public ActionResult Edit(int id = 0)
    {
        CarUser caruser = db.CarUsers.Find(id);
        if (caruser == null)
        {
            return HttpNotFound();
        }
        return View(caruser);
    }

    //
    // POST: /CarUser/Edit/5

    [HttpPost]
    public ActionResult Edit(CarUser caruser)
    {
        if (ModelState.IsValid)
        {
            db.Entry(caruser).State = EntityState.Modified;
            db.SaveChanges();
            return RedirectToAction("Index");
        }
        return View(caruser);
    }

    //
    // GET: /CarUser/Delete/5

    public ActionResult Delete(int id = 0)
    {
        CarUser caruser = db.CarUsers.Find(id);
        if (caruser == null)
        {
            return HttpNotFound();
        }
        return View(caruser);
    }

    //
    // POST: /CarUser/Delete/5

    [HttpPost, ActionName("Delete")]
    public ActionResult DeleteConfirmed(int id)
    {
        CarUser caruser = db.CarUsers.Find(id);
        db.CarUsers.Remove(caruser);
        db.SaveChanges();
        return RedirectToAction("Index");
    }

    protected override void Dispose(bool disposing)
    {
        db.Dispose();
        base.Dispose(disposing);
    }
}
}

//formdatacontext

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;

namespace MvcApplication1.Models
{
public class FormDataContext : DbContext
{
    public DbSet<CarUser> CarUsers
    { get; set; }
}
}

//formdatainitialiser

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using System.IO;

namespace MvcApplication1.Models
{
public class FormDataInitializer : DropCreateDatabaseAlways<FormDataContext>
{
    protected override void Seed(FormDataContext context)
    {
        base.Seed(context);

        var CarUsers = new List<CarUser>
        {
            new CarUser {
                ID = 1,
                Fname = "Craig",
                Sname = "Higginson",
            }
        };

        CarUsers.ForEach(s => context.CarUsers.Add(s));
        context.SaveChanges();

        }
    }

}

我的web.config文件中还包含以下内容

代码语言:javascript
复制
<connectionStrings>
<add name="FormDataContext"
     connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=FormData.mdf;Integrated Security=True" providerName="System.Data.SqlClient" />

这一切都很好地构建,当我导航到/caruser时,我能够创建新的记录。这些记录没有存储在我的数据库中。

如果我正确地引用了数据库,我是否需要首先在数据库中创建表,或者实体框架是否应该为我创建该表?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-12-10 00:14:30

如果您使用的是Code First方法,那么实体框架将为您构建该表。看起来您没有先使用Code,所以您需要在数据库中创建表。我假设您使用的是实体数据模型(.edmx)?如果是这样,您将在数据库中创建表,然后更新数据模型(.edmx)。如果您还没有创建您的.edmx文件,那么您需要这样做-- .edmx文件将包含您的所有CRUD操作。

我感到困惑的是,如果表不存在(即,如果您的数据模型表示的表没有映射到数据库中的实际表,因为它不存在),我会认为您的代码会抛出一个错误。所以,问题是,您的表是否已经存在?如果是,则逐行检查代码,找出没有保存记录的原因。如果它不存在,那么通过SQL Server Management Studio (或类似的)添加表,然后打开.edmx文件,右键单击出现的布局,单击"Update Model from database“。

票数 1
EN

Stack Overflow用户

发布于 2013-12-10 00:15:01

你可以在这里找到所有需要的信息:creating-an-entity-framework-data-model-for-an-asp-net-mvc-application

票数 1
EN

Stack Overflow用户

发布于 2013-12-10 15:35:50

  1. 首先,您需要在现有解决方案中添加一个edmx项目,该项目是数据库的模型,包含所有表和SP。
  2. 从您的操作方法调用另一个类,例如DataAccessLayer.cs.
  3. In
  4. ,添加对您的edmx项目的引用。
  5. 使用以下代码:

使用(var entity = new FormDataContext()) {//实体。将为您提供数据库中的所有表。}

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20475223

复制
相关文章

相似问题

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