ASP.NET MVC IDENTITY_INSERT设置为OFF

时间:2011-01-05 19:29:09

标签: asp.net-mvc entity-framework identity-insert

我的HomeController中有以下代码:

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

        [ValidateInput(false)]
        [AcceptVerbs(HttpVerbs.Post)]
        public ActionResult Create([Bind(Exclude = "Id")]Article articleToCreate)
        {
            if (!ModelState.IsValid)
                return View();

            try
            {
                _db.AddToArticleSet(articleToCreate);
                articleToCreate.posted = DateTime.Now;
                _db.SaveChanges();

                return RedirectToAction("Index");
            }
            catch
            {
                return View();
            }
        }

这是创建方法的视图

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

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

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

    <div id="create">

        <h2>Create News Article <span>( <%=Html.ActionLink("Cancel", "Index") %> )</span></h2>

        <% using (Html.BeginForm()) {%>

            <fieldset>
                <legend>Fields</legend>
                <p>
                    <label for="headline">Headline</label>
                    <%= Html.TextBox("headline") %>
                </p>
                <p>
                    <label for="story">Story <span>( HTML Allowed )</span></label>
                    <%= Html.TextArea("story") %>
                </p>
                <p>
                    <label for="image">Image URL</label>
                    <%= Html.TextBox("image") %>
                </p>
                <p>
                    <input type="submit" value="Post" />
                </p>
            </fieldset>

        <% } %>

    </div>
    <!-- END div#create -->

</asp:Content>

我尝试提交数据时遇到的问题是InnerException,表示IDENTITY_INSERT设置为off。但是,我的文章表中的ID(称为storyId)设置为自动增量,并且还设置为标识,也设置为主键/索引。

如何解决此问题?感谢。

1 个答案:

答案 0 :(得分:3)

您是否创建了Linq To SQL DBML文件,然后将数据库架构更改为全部以进行自动增量?我想你可能已经改变了架构,但忘了更新linq设计师。

只需删除设计器中的表格,然后从数据库中重新拖动它即可。