我正在尝试实现可以将结果填充到 Gridview 的搜索功能。我正在使用 LINQ 在 c# 中查询我的数据库。
我想弄清楚的问题是,如果用户想要通过多个搜索词搜索多个列/字段,那么我该怎么做呢?例如,如果我搜索包含这 3 个字段的表,并且我有一些数据,例如: > firstName | 姓氏 | 玩家# >>1. 迈克尔 | 约旦 | 12 >>2。迈克尔 | 约旦 | 24 >>3。迈克尔 | 约旦 | 45 >>4。德安德烈| 约旦 | 6 >> 5。杰罗姆| 约旦 | 44 >>6。约旦| 火花| 88
现在,如果我搜索 Jordan,我会得到所有信息:
如果我搜索迈克尔乔丹而不是我应该得到第 1、2、3 行。
如果我搜索 Jordan Sparks 88,我应该排在第 6 位。
所以我的问题是我不知道搜索词可能在表中的哪个位置,所以我必须搜索所有列/字段。在我当前的代码中,我有一些东西可以遍历每个列/字段名称并使用 Contains() 然后 || (“或”),但它仅适用于 1 个搜索词。
是否有一种优雅而简单的方法来搜索和过滤整个 linq 表,以便最小化列表?从那里我将该结果添加到数据源,然后绑定它。
@Sphinxxx 我正在使用典型的网格视图。它看起来像这样:
<asp:GridView ID="GridView" runat="server" AllowSorting="True" PagerStyle-Mode="NumericPages"
AutoGenerateColumns="false" Width="100%" CssClass="gridView" OnPageIndexChanging="GridView_PageIndexChanging"
AllowPaging="True" DataKeyNames="idPlayersList" OnRowCommand="GridView_RowCommand"
OnRowEditing="GridView_RowEditing" OnRowCancelingEdit="GridView_CancelEditRow"
OnRowUpdating="GridView_UpdateRow" OnRowDataBound="GridView_RowDataBound">
<RowStyle CssClass="rowStyle"></RowStyle>
<asp:BoundField DataField="FirstName" HeaderText="First Name" SortExpression="FirstName" />
<asp:BoundField DataField="LastName" HeaderText="Last Name" SortExpression="LastName" />
<asp:BoundField DataField="PlayersNumber" HeaderText="Players Number" SortExpression="PlayersNumber" />
<asp:TemplateField HeaderText="Team" SortExpression="Team">
<EditItemTemplate>
<asp:DropDownList ID="ddlTeam" runat="server" CssClass="dropdown" AutoPostBack="True"
AppendDataBoundItems="true" DataTextField="TeamName" DataValueField="idTeam">
</asp:DropDownList>
</EditItemTemplate>
<ItemTemplate>
<asp:Label ID="lblTeam" runat="server" Text='<%# Bind("TeamName") %>'></asp:Label>
</ItemTemplate>
</asp:TemplateField>
我当前的搜索功能如下所示:
/**
* This method is for button search functionality
*
*/
protected void btnSearch_Click(object sender, EventArgs e)
{
// Call to Entity Model Framework
DBModel.DBEntities context = new DBModel.DBEntities();
string[] searchTerms = txtSearch.Text.Trim().Split('&');
//Prepare to build a "players" query:
IQueryable<DBModel.playersList> playersListQuery = context.playersLists;
foreach (var term in searchTerms)
{
//Refine our query, one search term at a time:
playersListQuery = playersListQuery.Where(p => p.isDeleted == false && (p.FirstName.Contains(term.Trim()) ||
p.LastName.Contains(term.Trim()) ||
p.PlayersNumber.Contains(term.Trim()) ||
p.Team.Name.Contains(term.Trim())));
}
//Now we have the complete query. Get the results from the database:
var filteredplayersList = playersListQuery.Select(s => new
{
idPlayersList = s.idPlayersList,
FirstName = s.FirstName,
LastName = s.LastName,
PlayersNumber = s.PlayersNumber,
TeamName = s.Team.Name
}).ToList();
GridView.DataSource = filteredplayersList; //Connecting query to the datasource Gridview
GridView.DataBind(); //Binding Gridview
}