簡體   English   中英

使用Entity Framework在Database中創建表

[英]Create table in Database using Entity Framework

我正在嘗試使用Entity Framework將我的MVC項目與數據庫鏈接,但我無法弄清楚如何將新記錄存儲到數據庫中。 到目前為止,我有以下代碼:

//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文件中也有以下內容

<connectionStrings>
<add name="FormDataContext"
     connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=FormData.mdf;Integrated Security=True" providerName="System.Data.SqlClient" />

這一切都很好,當我導航到/ caruser時,我能夠創建新的記錄。 這些記錄未存儲在我的數據庫中。

我是否需要首先在數據庫中創建表,或者如果我已正確引用數據庫,Entity Framework是否應該為我創建此表?

如果您使用Code First方法,那么Entity Framework將為您構建表。 看起來您沒有使用Code First,因此您將在數據庫中創建表。 我假設您正在使用實體數據模型(.edmx)? 如果是這樣,您將在數據庫中創建表,然后更新數據模型(.edmx)。 如果尚未創建.edmx文件,則需要執行此操作 - .edmx文件將包含所有CRUD操作。

我感到困惑的是我想象如果表不存在,你的代碼會拋出一個錯誤(即如果數據模型所代表的表沒有映射到數據庫中的實際表,因為它沒有存在)。 所以,問題是,你的桌子已經存在了嗎? 如果是,則逐行逐步執行代碼以找出未保存記錄的原因。 如果它不存在,則通過SQL Server Management Studio(或類似)添加表,然后打開.edmx文件,右鍵單擊出現的布局,單擊“從數據庫更新模型”。

您可以在這里找到所有需要的信息: 創建一個實體框架數據模型用於asp-net-mvc-application

  1. 首先,您已將edmx項目添加到現有解決方案中,該解決方案是db的模型,包含所有表和SP。
  2. 從你的action方法調用另一個類,比如DataAccessLayer.cs
  3. DataAccessLayer.cs ,添加對edmx項目的引用。
  4. 使用此代碼:

     using (var entity = new FormDataContext()) { //entity. will give you all the tables in the database. } 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM