使用EntityDataSource和DetailsView插入多个表

时间:2012-06-18 19:27:50

标签: asp.net entity-framework-4 entity-framework-4.1

使用我的新网站,我正在使用edmx文件和实体数据源从正常的n层设置转换到Entity框架站点。我有一个SiteUsersAdd.aspx页面,这里是标记...

<asp:EntityDataSource ID="SiteUserDataSource" runat="server" 
                ContextTypeName="NutritionBridgeModel.NutritionBridgeEntities" 
                EnableFlattening="False" EntitySetName="SiteUsers" EnableInsert="True" 
                Include="Person" ConnectionString="name=NutritionBridgeEntities" 
                DefaultContainerName="NutritionBridgeEntities" >
            </asp:EntityDataSource>
            <asp:EntityDataSource ID="DataUserTypes" runat="server" 
                ConnectionString="name=NutritionBridgeEntities" 
                DefaultContainerName="NutritionBridgeEntities" EnableFlattening="False" 
                EntitySetName="SiteUserTypes" Select="it.[SiteUserTypeID], it.[Description]">
            </asp:EntityDataSource>
            <asp:EntityDataSource ID="DataSubscriptionTypes" runat="server" 
                ConnectionString="name=NutritionBridgeEntities" 
                DefaultContainerName="NutritionBridgeEntities" EnableFlattening="False" 
                EntitySetName="SubscriptionTypes" 
                Select="it.[Description], it.[SubscriptionTypeID]">
            </asp:EntityDataSource>



            <asp:DetailsView ID="detailsInsertSiteUser" runat="server" AutoGenerateRows="False" DataSourceID="SiteUserDataSource" DefaultMode="Insert" CssClass="standardTable" >
                <Fields>
                    <asp:BoundField DataField="FirstName" HeaderText="First Name" ReadOnly="True" HeaderStyle-CssClass="rowHeader" SortExpression="FirstName"  ControlStyle-CssClass="standardTextbox" />
                    <asp:BoundField DataField="LastName" HeaderText="Last Name" ReadOnly="True" HeaderStyle-CssClass="rowHeader" SortExpression="LastName" ControlStyle-CssClass="standardTextbox" />
                    <asp:BoundField DataField="Email" HeaderText="Email" ReadOnly="True" HeaderStyle-CssClass="rowHeader" SortExpression="Email" ControlStyle-CssClass="standardTextbox" />
                    <asp:BoundField DataField="Password" HeaderText="Password" ReadOnly="True" HeaderStyle-CssClass="rowHeader" SortExpression="Password" ControlStyle-CssClass="standardTextbox" />
                    <asp:TemplateField HeaderText="User Type" SortExpression="UserTypeID" HeaderStyle-CssClass="rowHeader">
                        <InsertItemTemplate>
                            <asp:DropDownList ID="DropDownList1" runat="server" 
                                DataSourceID="DataUserTypes" DataTextField="Description" 
                                DataValueField="SiteUserTypeID" CssClass="standardDropdown">
                            </asp:DropDownList>
                        </InsertItemTemplate>
                    </asp:TemplateField>
                    <asp:CheckBoxField DataField="Active" HeaderText="Active" ReadOnly="True" HeaderStyle-CssClass="rowHeader" SortExpression="Active" />
                    <asp:TemplateField HeaderText="Subscription Type" HeaderStyle-CssClass="rowHeader" SortExpression="SubscriptionTypeID">

                        <InsertItemTemplate>
                            <asp:DropDownList ID="ddlSubscriptionTypes" runat="server" 
                                DataSourceID="DataSubscriptionTypes" DataTextField="Description" 
                                DataValueField="SubscriptionTypeID" CssClass="standardDropdown">
                            </asp:DropDownList>
                        </InsertItemTemplate>

                    </asp:TemplateField>
                    <asp:CheckBoxField DataField="TestAccount" HeaderText="Test Account" HeaderStyle-CssClass="rowHeader" ReadOnly="True" SortExpression="TestAccount" />
                    <asp:CommandField ShowInsertButton="True" ControlStyle-CssClass="standardButton" ItemStyle-CssClass="submitArea" />
                </Fields>
            </asp:DetailsView>

我有一个人员表和一个siteusers表:

PERSONS:PersonID,FirstName,LastName SITEUSERS:SiteUserID,PersonID等。

因此,当我创建一个新的SITEUSER时,我还想创建一个新的PERSON。使用我的entitydatasource有一种优雅的方法吗?它需要在代码背后吗?如果是这样的话是什么样的?到目前为止,我假设它需要是这样的,如果它在后面的代码中......

 Protected Sub detailsInsertSiteUser_ItemInserting(sender As Object, e As System.Web.UI.WebControls.DetailsViewInsertEventArgs) Handles detailsInsertSiteUser.ItemInserting
        NutritionBridgeContext = New NutritionBridgeEntities

        'insert new person
        Dim intPersonID As Integer = 0

        'use the generated identity field to insert into SiteUser record
        e.Values("PersonID") = intPersonID
    End Sub

0 个答案:

没有答案