1

我正在使用 C# 和 SQL Server 2005 开发一个 ASP .Net MVC 3 应用程序。
我也在使用实体框架和代码优先方法。
我有一个模型“Poste”,其中包含一些属性。
Poste 的视图(创建、编辑、删除...)是在我创建控制器时自动创建的。
我在这个模型中有一个外键。
此外键的值显示在“DropDownList”中。
问题是这些值与我的外键的右表无关。

解释更多:
我有 3 个表,它们是:

  • Poste ( ID_Poste , Nom_Poste,...,#ID_Ligne)
  • Ligne ( ID_Ligne , #ID_UF)
  • 超滤 ( ID_UF )

在我的表单中,DropDownList 通常用于显示ID_Ligne(Poste 表中的外键),但事实上,显示的值是UF表的值(ID_UF 精确)。
所以,它是表 UF 的投影。
我不知道原因。
我很抱歉英语,,,而且不够清楚,我会尝试解释更多。
这是 Poste 的模型:

namespace MvcApplication2.Models
{
    public class Poste
    {
        [Required]
        [Key]
        [Display(Name = "ID Poste :")]
        public string ID_Poste { get; set; }

        [Required]
        [Display(Name = "Nom Poste:")]
        public string nom_Poste { get; set; }

        [Required]
        [Display(Name = "Application :")]
        public string Application { get; set; }

        [Required]
        [Display(Name = "In Poste :")]
        public string In_Po { get; set; }

        [Required]
        [Display(Name = "Out Poste :")]
        public string Out_Po { get; set; }

        [Required]
        [Display(Name = "Etat :")]
        public string Etat { get; set; }

        [Required]
        [ForeignKey("Ligne")]
        [Display(Name = "ID Ligne :")]
        public string ID_Ligne { get; set; }

        [Required]
        [Display(Name = "Mouvement :")]
        public string Mouvement { get; set; }

        public virtual Ligne Ligne { get; set; }
        public IEnumerable<Ligne> Lignes { get; set; }

        public virtual ICollection<Poste> Postes { get; set; }
    }
}
}

这是控制器:

namespace MvcApplication2.Controllers
{ 
    public class PosteController : Controller
    {
        private GammeContext db = new GammeContext();

        //
        // GET: /Poste/

        public ViewResult Index()
        {
            var postes = db.Postes.Include(p => p.Ligne);
            return View(postes.ToList());
        }

        //
        // GET: /Poste/Details/5

        public ViewResult Details(string id)
        {
            Poste poste = db.Postes.Find(id);
            return View(poste);
        }

        //
        // GET: /Poste/Create

        public ActionResult Create()
        {
            ViewBag.ID_Ligne = new SelectList(db.Lignes, "ID_Ligne", "ID_UF");
            return View();
        } 

        //
        // POST: /Poste/Create

        [HttpPost]
        public ActionResult Create(Poste poste)
        {
            if (ModelState.IsValid)
            {
                db.Postes.Add(poste);
                db.SaveChanges();
                return RedirectToAction("Index");  
            }

            ViewBag.ID_Ligne = new SelectList(db.Lignes, "ID_Ligne", "ID_UF", poste.ID_Ligne);
            return View(poste);
        }

        //
        // GET: /Poste/Edit/5

        public ActionResult Edit(string id)
        {
            Poste poste = db.Postes.Find(id);
            ViewBag.ID_Ligne = new SelectList(db.Lignes, "ID_Ligne", "ID_UF", poste.ID_Ligne);
            return View(poste);
        }

        //
        // POST: /Poste/Edit/5

        [HttpPost]
        public ActionResult Edit(Poste poste)
        {
            if (ModelState.IsValid)
            {
                db.Entry(poste).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            ViewBag.ID_Ligne = new SelectList(db.Lignes, "ID_Ligne", "ID_UF", poste.ID_Ligne);
            return View(poste);
        }

        //
        // GET: /Poste/Delete/5

        public ActionResult Delete(string id)
        {
            Poste poste = db.Postes.Find(id);
            return View(poste);
        }

        //
        // POST: /Poste/Delete/5

        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(string id)
        {            
            Poste poste = db.Postes.Find(id);
            db.Postes.Remove(poste);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

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

最后是 Create 的视图:

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.master" Inherits="System.Web.Mvc.ViewPage<MvcApplication2.Models.Poste>" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    Create
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

<h2>Ajouter</h2>

<script src="<%: Url.Content("~/Scripts/jquery.validate.min.js") %>" type="text/javascript"></script>
<script src="<%: Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js") %>" type="text/javascript"></script>

<% using (Html.BeginForm()) { %>
    <%: Html.ValidationSummary(true) %>
    <fieldset>
        <legend>Poste</legend>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.ID_Poste) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.ID_Poste) %>
            <%: Html.ValidationMessageFor(model => model.ID_Poste) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.nom_Poste) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.nom_Poste) %>
            <%: Html.ValidationMessageFor(model => model.nom_Poste) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Application) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.Application) %>
            <%: Html.ValidationMessageFor(model => model.Application) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.In_Po) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.In_Po) %>
            <%: Html.ValidationMessageFor(model => model.In_Po) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Out_Po) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.Out_Po) %>
            <%: Html.ValidationMessageFor(model => model.Out_Po) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Etat) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.Etat) %>
            <%: Html.ValidationMessageFor(model => model.Etat) %>
        </div>



        <div class="editor-label">
            <%: Html.LabelFor(model => model.ID_Ligne, "Ligne") %>
        </div>
        <div class="editor-field">
            <%: Html.DropDownList("ID_Ligne", String.Empty) %>
            <%: Html.ValidationMessageFor(model => model.ID_Ligne) %>
        </div>

        <div class="editor-label">
            <%: Html.LabelFor(model => model.Mouvement) %>
        </div>
        <div class="editor-field">
            <%: Html.EditorFor(model => model.Mouvement) %>
            <%: Html.ValidationMessageFor(model => model.Mouvement) %>
        </div>

        <p>
            <input type="submit" value="Ajouter" />
            <input type="reset" value="Vider" />
        </p>
    </fieldset>
<% } %>

<div>
    <%: Html.ActionLink("Retour à la liste", "Index") %>
</div>

</asp:Content>

Ps:执行后,一个新列(Poste_ID_Poste)在我的基础中自动创建 2 个表:Poste 和 Ligne。

4

1 回答 1

0

您的 Poste 课程中有一个 ICollection of Poste。我不是 100% 确定,但这听起来像是对我的周期性引用(你有一个类本身就是一个集合)

您还有一个虚拟的 Lignes 和一个 IEnumerable 的 Lignes。我认为您没有正确使用前面提到的两个项目中的任何一个。

于 2013-05-06T05:56:40.013 回答