我有LinqDataSource附加到Asp.net Web应用程序中的GridView。
<asp:LinqDataSource ID="LinqDataSource1" runat="server" ContextTypeName="DataClassesDataContext" OnInit="LinqDataSource1_Init"
EnableDelete="True"
EntityTypeName="Id" TableName="CompanysCourses"
OnDeleting="Course_Deleting" OnDeleted="Course_Deleted">
</asp:LinqDataSource>
在OnInit事件中,我修改了select和where属性,如
this.LinqDataSource1.Where = "CompanyId == " + UserManager.CompanyId;
this.LinqDataSource1.Select= "Course";
我选择名为CompanysCourses的表格,之后过滤结果并根据公司ID选择特定课程
这是我的网格视图
<asp:GridView ID="grdVwCourses" runat="server"
AllowPaging="True" AllowSorting="True"
AutoGenerateColumns="False"
DataKeyNames="Id" DataSourceID="LinqDataSource1"
OnSelectedIndexChanged="grdVwCourses_SelectedIndexChanged"
CssClass="table table-responsive"
PageSize="10" GridLines="Horizontal"
meta:resourcekey="GridView1Resource1">
<EmptyDataTemplate>
<asp:Label runat="server" ID="NotFoundLabel" Text="" meta:resourcekey="NotFoundLabelResource1"></asp:Label>
</EmptyDataTemplate>
<Columns>
<asp:TemplateField HeaderText="#" meta:resourcekey="HeaderId">
<ItemTemplate>
<%# Container.DataItemIndex + 1 %>
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="Id" Visible="false"/>
<asp:BoundField DataField="Name" HeaderText="Name" SortExpression="Name" meta:resourcekey="BoundFieldResource1" />
<asp:BoundField DataField="EnglishName" HeaderText="EnglishName" SortExpression="EnglishName" meta:resourcekey="BoundFieldResource2" />
<asp:BoundField DataField="CreatedDate" HeaderText="CreatedDate" SortExpression="CreatedDate" meta:resourcekey="BoundFieldResource3" />
<asp:TemplateField meta:resourcekey="TemplateFieldResource1">
<ItemTemplate>
<asp:HyperLink ID="userLink" runat="server" NavigateUrl='<%# GetCategoriesLink(Eval("Id")) %>' Text="Categories" meta:resourcekey="userLinkResource1" />
</ItemTemplate>
</asp:TemplateField>
<asp:CommandField ShowSelectButton="True" ShowDeleteButton="True" meta:resourcekey="CommandFieldResource1" />
</Columns>
</asp:GridView>
我在网格视图中启用了删除,但是当点击删除时我得到了此异常
LinqDataSource&#39; LinqDataSource1&#39;不支持Select属性 何时启用删除,插入或更新操作。
我已覆盖On_Deleting事件,以显示确认对话框
protected void Course_Deleting(object sender, LinqDataSourceDeleteEventArgs e)
{
e.Cancel = true
this.panMessage.Visible = true;
int id = ((Course)e.OriginalObject).Id;
ViewState["DeleteObject"] = id;
}
我想知道这个问题的原因是什么。
修改 被称为重复的问题并没有我所寻求的答案,细节也不同。
答案 0 :(得分:0)
我今天在一些遗留项目中遇到了同样的问题,因为显示此小部件的错误在您使用SELECT语句时不支持删除。
所以解决方案是从这个数据源中删除你的select语句,即删除这一行:
this.LinqDataSource1.Select= "Course";
然后在gridview上将DataKeyNames更改为您的表ID名称,并更改导航属性以访问字段,例如,字段中每列的Course.Id,Course.Name等。
最后一件事是转换为主表并使用any字段来访问该表子值的Id。
int id = ((Course)e.OriginalObject).Id;