При привязке данных: LINQ to Entities не распознает метод метода System.String ToString () - PullRequest
1 голос
/ 19 ноября 2011

Я использую LINQ to Entities

Мой GridView выглядит следующим образом:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" AllowPaging="True"
    EmptyDataText="No Data" CellPadding="3" CellSpacing="1"
    AllowSorting="True" OnPageIndexChanging="GridView1_PageIndexChanging" OnRowCancelingEdit="GridView1_RowCancelingEdit"
    OnRowEditing="GridView1_RowEditing" OnRowUpdating="GridView1_RowUpdating" CssClass="gridview"
    OnSorting="GridView1_Sorting" HorizontalAlign="Center">
    <AlternatingRowStyle BackColor="#F0F0F0" />
    <Columns>
        <asp:BoundField HeaderText="ID" DataField="ID" ReadOnly="True" SortExpression="ID" />
        <asp:BoundField HeaderText="Name" DataField="SoftwareName" SortExpression="Name" />
        <asp:BoundField HeaderText="Key" DataField="Key" SortExpression="Key" />
        <asp:BoundField HeaderText="Date" DataField="Date" ItemStyle-CssClass="date_td" SortExpression="Date"
            ReadOnly="True">
            <ItemStyle CssClass="date_td"></ItemStyle>
        </asp:BoundField>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:ImageButton runat="server" ToolTip="edit" ID="EditButton" CommandName="Edit"
                    ImageUrl="~/images/edit.png" />
            </ItemTemplate>
            <EditItemTemplate>
                <asp:ImageButton runat="server" ID="UpdateButton" ToolTip="Submit" CommandName="Update"
                    ImageUrl="~/images/ok.gif" />
                <asp:ImageButton runat="server" ID="Cancel" ToolTip="Submit" CommandName="Cancel"
                    ImageUrl="~/images/cancel.gif" />
            </EditItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:ImageButton runat="server" ToolTip="Delete" ID="btnDelete" CommandName="cDelete"
                    ImageUrl="~/images/delete.png" OnCommand="OnDelete" CommandArgument='<%# Bind("id") %>'
                    OnClientClick="return confirm('Are you sure ?')" />
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
    <PagerSettings Mode="NumericFirstLast" />
</asp:GridView>

Я заполняю GridView следующим кодом c #:

private IQueryable SortGridView()
{
    IQueryable<Softwares> softwares = Search();

    if (softwares == null) return null;

    string sortExpression = (ViewState["SortExpression"] as string) == null
                                ? "ID"
                                : ViewState["SortExpression"] as string;
    string lastDirection = (ViewState["SortDirection"] as string) == null
                                ? "ASC"
                                : ViewState["SortDirection"] as string;

    switch (sortExpression)
    {
        case "ID":
            softwares = (lastDirection == "ASC")
                                ? softwares.OrderBy(q => q.id)
                                : softwares.OrderByDescending(q => q.id);
            break;

        case "Name":
            softwares = lastDirection == "ASC"
                            ? softwares.OrderBy(q => q.softwareName)
                            : softwares.OrderByDescending(q => q.softwareName);
            break;

        case "Key":
            softwares = (lastDirection == "ASC")
                            ? softwares.OrderBy(q => q.Keys.Key)
                            : softwares.OrderByDescending(q => q.Keys.Key);
            break;

        case "Date":
            softwares = lastDirection == "ASC"
                            ? softwares.OrderBy(q => q.Date)
                            : softwares.OrderByDescending(q => q.Date);
            break;
    }

    return from q in softwares
            select new
                        {
                            ID = q.id,
                            SoftwareName = q.softwareName,
                            Key = q.Keys.Key
                            Date = q.Date.ToString()
                        };
}

protected void ButtonSearch_Click(object sender, EventArgs e)
{
    GridView1.DataSource = SortGridView();
    GridView1.DataBind();// <<--- Exception
}

Но в ButtonSearch_Click я получаю следующее исключение:

LINQ to Entities не распознает метод метода System.String ToString (), и этот метод не может быть преобразован в выражение хранилища

Я уже делал это с LINQ to SQL без проблем, что здесь с этим не так?

1 Ответ

1 голос
/ 19 ноября 2011

Запросы LINQ to Entities внутренне преобразуются в операторы sql. В вашем случае это просто, что поставщик LINQ to Entity не может отобразить вызов toString в подходящий оператор SQL. Вы можете извлечь данные из LINQ для объекта, а затем перечислить в автономном режиме и внести необходимые изменения, например:

var data = (from q in softwares
            select new
                        {
                            ID = q.id,
                            SoftwareName = q.softwareName,
                            Key = q.Keys.Key
                            Date = q.Date
                        }).ToList();

, а затем преобразовать часть Date, вызвав метод ToString () в автономном режиме.

data.ForEach(item => item.Date = item.Date.ToString());

Вы возвращаете анонимный тип из вашего метода. Анонимные типы доступны только внутри класса, в котором они определены. Вы можете попробовать что-то вроде кода, который я дал ниже:

private IList<SoftwareInfo> SortGridView()
{
    // regular code

    return (from q in softwares
            select new SoftwareInfo
                        {
                            ID = q.id,
                            SoftwareName = q.softwareName,
                            Key = q.Keys.Key,
                            Date = q.Date
                        }).ToList();
}


public class SoftwareInfo
{
    public int ID {get;set;}
    public string SoftwareName {get;set;}
    public string  Key {get;set;}
    public DateTime Date {get;set;}
}

protected void ButtonSearch_Click(object sender, EventArgs e)
{
    GridView1.DataSource = SortGridView();
    GridView1.DataBind();// <<--- Exception
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...