Я просмотрел сотни страниц результатов Google, пытаясь найти ответ за это в течение последних нескольких дней.Внешнее поле таблицы ключей, которое не отображается в окне просмотра списка поддерживаемых динамических данных
Использование автономной страницы динамических данных для отображения таблицы с использованием EntityDataSource, причем одно из полей является внешним ключом для подтаблицы. Я хочу, чтобы он отображал значение из подтаблицы. Я играл с упрощенным случаем, используя базу данных NorthWinds (см. Код ниже). Если я назначу DynamicControl DataField = «Поставщик», вместо этого отобразит имя подкатегории/класса («DAL.Supplier»). Если я попытаюсь назначить DataField = «Supplier.CompanyName», это приведет к ошибкам с «В таблице« Продукт »нет столбца с именем« Supplier.CompanyName »». Поскольку я хочу использовать возможности редактирования динамических данных, используя шаблонное поле с <% # Eval («Supplier.CompanyName»)%> отсутствует.
Возможно ли это с помощью отдельной страницы динамических данных? Он четко работает в полностью защищенной системе. Или я (надеюсь) просто что-то пропустил? Спасибо.
Test.aspx
<%@ Page Title="" Language="VB" MasterPageFile="~/Master/Site.master" AutoEventWireup="false" CodeFile="Test.aspx.vb" Inherits="Test" %>
<asp:Content ID="Content3" ContentPlaceHolderID="BodyContent" Runat="Server">
<asp:ListView ID="ListView1" runat="server" DataSourceID="theDataSource" DataKeyNames="ProductID">
<ItemTemplate>
<tr>
<td>
<asp:DynamicControl runat="server" DataField="ProductID" Mode="Edit" />
</td>
<td>
<asp:DynamicControl runat="server" DataField="ProductName" Mode="Edit" />
</td>
<td>
<asp:DynamicControl runat="server" DataField="Supplier" Mode="Edit" />
</td>
<td>
<asp:DynamicControl runat="server" DataField="UnitPrice" Mode="Edit" />
</td>
<td>
<asp:DynamicControl runat="server" DataField="Discontinued" Mode="Edit" />
</td>
</tr>
</ItemTemplate>
<LayoutTemplate>
<table runat="server">
<tr runat="server">
<td runat="server">
<table id="itemPlaceholderContainer" runat="server" border="0">
<tr runat="server">
<th runat="server">
ProductID
</th>
<th runat="server">
ProductName
</th>
<th runat="server">
Supplier
</th>
<th runat="server">
UnitPrice
</th>
<th runat="server">
Discontinued
</th>
</tr>
<tr id="itemPlaceholder" runat="server">
</tr>
</table>
</td>
</tr>
<tr runat="server">
<td runat="server">
</td>
</tr>
</table>
</LayoutTemplate>
</asp:ListView>
<asp:EntityDataSource ID="theDataSource" runat="server"
ConnectionString="name=NorthwindEntities"
DefaultContainerName="NorthwindEntities" EnableDelete="True"
EnableFlattening="False" EnableInsert="True" EnableUpdate="True"
Include="Supplier"
EntitySetName="Products">
</asp:EntityDataSource>
</asp:Content>
Test.aspx.vb
Imports System.Web.DynamicData
Imports DAL
Partial Class Test
Inherits System.Web.UI.Page
Protected table As MetaTable
Protected Sub Page_Init(sender As Object, e As System.EventArgs) Handles Me.Init
Listview1.EnableDynamicData(GetType(Product))
table = theDataSource.GetTable()
Title = table.DisplayName
End Sub
End Class