设置linqdatasource的where子句和参数,如Linq查询

时间:2013-05-14 08:52:27

标签: c# asp.net linq listview linqdatasource

我有一个列表视图,并通过选择相关关键字的linq查询在代码隐藏中绑定它

MyDataContext dcxt = new MyDataContext();
string x = "searchword"; // i get x from user
var query = from ak in dcxt.WordIndexes
            where ak.Word == x
            from a in ak.Keywords
            where a.Comps.Approved &&
            a.Comps.Active &&
            a.Approved 
            orderby a.ETbm descending
            select a;

ListView1.DataSource = query;
ListView1.DataBind();

我在WordIndexes -> Keywords之间有一对多的关系, 也是Comps -> Keyswords之间的一对多。

现在我想使用linqdatasource,所以我可以让linqdatasource处理分页。但是我不能像这个linq查询一样设置where子句。

<asp:LinqDataSource ID="lds2" runat="server" 
    ContextTypeName="MyDataContext" EntityTypeName="" 
    OrderBy="" TableName="Keywords"
    Where="">
</asp:LinqDataSource>

我试图使用datapager(没有linqdatasource)进行分页,但是如果结果包含很多项目,它会非常慢。我之前使用linqdatasource进行更简单的查询,但这对我来说有点复杂,因为表之间的关系,我不知道从哪里开始构建where子句。有什么帮助吗?

更新

我最终使用LinqDataSourceSelectEvent与DataPager一样,如答案

中所述
protected void linqDS_Selecting(object sender, LinqDataSourceSelectEventArgs e)
{
    var query = from ak in dcxt.WordIndexes
                where ak.Word == x
                from a in ak.Keywords
                where a.Comps.Approved &&
                a.Comps.Active &&
                a.Approved 
                orderby a.ETbm descending
                select a;

    e.Arguments.TotalRowCount = query.Count();
    e.Result = query.Skip(DataPager1.StartRowIndex).Take(DataPager1.PageSize);
}

1 个答案:

答案 0 :(得分:0)

您可以使用LinqDataSource_Selecting事件并将查询传递给