使用 Linq (asp.net) 绑定 Gridview 数据源

Posted

技术标签:

【中文标题】使用 Linq (asp.net) 绑定 Gridview 数据源【英文标题】:Bind Gridview Datasource with Linq (asp.net) 【发布时间】:2013-09-22 12:45:22 【问题描述】:

基本上,我想做的是将 Linq 查询绑定到 gridview 的数据源。到目前为止,这是我的代码:

ddgDossiers.DataSource = (From c In dbConnection.Campaigns.AsQueryable Select c).ToList
ddgDossiers.DataBind()

它编译并且不抱怨任何东西。

<asp:GridView ID="ddgDossiers" runat="server" CellPadding="0" CellSpacing="0" AllowSorting="True"
AutoGenerateColumns="False" EnableViewState="True" AllowPaging="True" PageSize="35"
PagerStyle-HorizontalAlign="Right" PagerStyle-Mode="NumericPages" PagerStyle-Position="TopAndBottom"
BorderWidth="1" GridLines="Both" BorderColor="#000000" CssClass="mGrid" PagerStyle-CssClass="pgr">
<PagerSettings Position="TopAndBottom" />
<Columns>
    <asp:TemplateField Visible="false" HeaderText="UniqueID" ItemStyle-HorizontalAlign="left"
        HeaderStyle-HorizontalAlign="Center" ItemStyle-Width="1%" HeaderStyle-Width="1%"
        HeaderStyle-CssClass="GridTitle" ItemStyle-CssClass="rowReport" SortExpression="UniqueId">
        <ItemTemplate>
            <asp:Label ID="lblUniqueID" runat="server" Text='<%#Container.DataItem("Campaign.CampaignId").ToString%>' />
        </ItemTemplate>
    </asp:TemplateField>
</Columns>
</asp:GridView>

错误指向这一行:

<asp:Label ID="lblUniqueID" runat="server" Text='<%#Container.DataItem("CampaignId").ToString%>' />

并说:找不到类型“活动”的默认成员。

这有什么关系吗?提前致谢。

【问题讨论】:

您不需要执行 .ToList 来绑定它。 Campaigns 表是否包含 CampaignId 列? 尝试删除广告系列。只需使用 CampaignId 我的错。这是一个考验。我已经只使用了 CampaignId。是的,该表包含此字段。 【参考方案1】:

换行

Text='<%#Container.DataItem("Campaign.CampaignId").ToString%>'

Text='<%# DataBinder.Eval(Container.DataItem, "CampaignId") %>' 

【讨论】:

正是我需要的。非常感谢!!!!奇迹般有效。我会评价你的答案,但我还没有足够的代表^^。

以上是关于使用 Linq (asp.net) 绑定 Gridview 数据源的主要内容,如果未能解决你的问题,请参考以下文章

C#(ASP.NET) MVC kendo grid如何绑定一个数据库返回的datatable(要最简单的)

Grid中的kendoui ClientTemplate在asp.net mvc 4中不起作用

asp.net中用datatable给dropdownlist绑定数据

ASP.NET 中 把返回的List<Dictionary<string, object>>的第一条记录的某个值绑定到Button中

什么时候应该在 ASP.NET 控件中使用 # 和 =?

ASP.NET中的Linq怎么用?